가져오기 약속으로 오류 잡기: 조건부 거부
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!