ホームページ >ウェブフロントエンド >jsチュートリアル >Fetch Promise でエラーをキャッチする方法: 条件付き拒否が機能しないのはなぜですか?

Fetch Promise でエラーをキャッチする方法: 条件付き拒否が機能しないのはなぜですか?

DDD
DDDオリジナル
2024-11-13 03:36:02371ブラウズ

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

Fetch Promises によるエラーのキャッチ: 条件付き拒否

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 を実行し、ステータス コードが OK でない場合はリデューサーでエラーをキャッチします。ただし、コードは意図したとおりに動作しません。Promise は拒否されません。

Fetch Promises について

ネットワーク エラーが発生した場合、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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。