> 웹 프론트엔드 > JS 튜토리얼 > Fetch Promise로 오류를 잡는 방법: 조건부 거부가 작동하지 않는 이유는 무엇입니까?

Fetch Promise로 오류를 잡는 방법: 조건부 거부가 작동하지 않는 이유는 무엇입니까?

DDD
풀어 주다: 2024-11-13 03:36:02
원래의
349명이 탐색했습니다.

How to Catch Errors with Fetch Promises: Why Conditional Rejection Doesn't Work?

가져오기 약속으로 오류 잡기: 조건부 거부

Redux 애플리케이션에서 개발자는 종종 비동기 요청에 가져오기를 사용합니다. 그러나 요청이 실패할 때 오류를 처리하는 것은 어려울 수 있으며, 특히 요청이 OK가 아닌 상태 코드를 반환하는 경우 더욱 그렇습니다.

다음 코드 조각을 고려하세요.

function fetchVehicle(id) {
    return dispatch => {
        return dispatch({
            type: 'FETCH_VEHICLE',
            payload: fetch(`http://swapi.co/api/vehicles/${id}/`)
                .then(status)
                .then(res => res.json())
                .catch(error => {
                    throw(error);
                })
        });
    };
}

function status(res) {
    if (!res.ok) {
        return Promise.reject()
    }
    return res;
}
로그인 후 복사

목표는 거부하는 것입니다. 상태 코드가 정상이 아닌 경우 약속을 이행하고 감속기에서 오류를 포착합니다. 그러나 코드가 의도한 대로 작동하지 않습니다. Promise가 거부되지 않습니다.

Fetch Promise 이해

Fetch Promise는 네트워크 오류가 발생할 때 TypeError가 발생하는 경우에만 거부됩니다. . 4xx 또는 5xx 상태 코드가 있는 응답은 네트워크 오류로 간주되지 않으므로 오류가 발생하지 않습니다.

사용자 정의 오류 발생

이러한 비네트워크 오류를 포착하려면, 상태 코드가 실패한 요청을 나타내는 경우 수동으로 오류를 발생시킬 수 있습니다.

function fetchVehicle(id) {
  return fetch(`http://swapi.co/api/vehicles/${id}/`)
    .then(response => {
      if (!response.ok) {
        throw new Error('Something went wrong');
      }
      return response.json();
    })
    .catch(error => {
      console.log(error);
    });
}
로그인 후 복사

이제 요청이 반환되면 OK가 아닌 상태 코드인 경우 오류 처리기를 트리거하고 오류 메시지를 기록합니다. 그러면 감속기가 이 오류를 적절하게 처리할 수 있습니다.

위 내용은 Fetch Promise로 오류를 잡는 방법: 조건부 거부가 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿