Maison >interface Web >js tutoriel >Comment détecter les erreurs avec les promesses de récupération : pourquoi le rejet conditionnel ne fonctionne pas ?

Comment détecter les erreurs avec les promesses de récupération : pourquoi le rejet conditionnel ne fonctionne pas ?

DDD
DDDoriginal
2024-11-13 03:36:02383parcourir

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

Détecter les erreurs avec les promesses de récupération : rejet conditionnel

Dans les applications Redux, les développeurs utilisent souvent la récupération pour les requêtes asynchrones. Cependant, la gestion des erreurs lorsque la requête échoue peut être difficile, surtout si la requête renvoie un code d'état non OK.

Considérez l'extrait de code suivant :

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;
}

L'objectif est de rejeter la promesse et détectez l'erreur dans le réducteur si le code d'état n'est pas OK. Cependant, le code ne fonctionne pas comme prévu : la promesse n'est pas rejetée.

Comprendre les promesses de récupération

Les promesses de récupération ne sont rejetées qu'avec une TypeError lorsqu'une erreur réseau se produit . Les réponses avec des codes d'état 4xx ou 5xx ne sont pas considérées comme des erreurs réseau, l'erreur n'est donc pas générée.

Lancement d'erreurs personnalisées

Pour détecter ces erreurs non liées au réseau, nous pouvons générer manuellement une erreur si le code d'état indique une requête ayant échoué :

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);
    });
}

Maintenant, si la requête renvoie un code d'état non OK, cela déclenchera le gestionnaire d'erreurs et enregistrera le message d'erreur. Le réducteur peut alors gérer cette erreur de manière appropriée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn