Maison >interface Web >js tutoriel >Comment utiliser Promise.race pour ajouter un délai d'attente pour récupérer les appels

Comment utiliser Promise.race pour ajouter un délai d'attente pour récupérer les appels

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-01 18:18:11365parcourir

How to use Promise.race to add timeout to fetch calls

L'API fetch est très pratique pour effectuer des requêtes réseau, mais elle n'est pas livrée avec une fonction de délai d'attente intégrée. Cela signifie que votre application peut se bloquer indéfiniment si le réseau est lent ou si le serveur ne répond pas.

Heureusement, JavaScript est un langage polyvalent, centré sur la programmation événementielle, fournissant un ensemble de fonctions utilitaires regroupées dans l'objet Promise. En utilisant la méthode Promise.race, nous pouvons créer un mécanisme de délai d'attente pour nos appels de récupération. De cette façon, nous pouvons garder nos applications réactives, même lorsque les choses ne se passent pas comme prévu avec le réseau.

Je vais donc vous expliquer comment implémenter ce délai d'attente à l'aide de Promise.race. Nous commencerons par un exemple de récupération simple, puis nous l'améliorerons en ajoutant un délai d'attente. Je partagerai également un scénario réel dans lequel nous traitons des jetons CSRF pour vous montrer comment cette méthode fonctionne dans un contexte sécurisé.

Supposons que nous ayons ceci :

// Prepare fetch options
const options = {
    method: method,
    headers: {
        'Content-Type': 'application/json',
        'Accept': 'application/json',
        'X-CSRF-TOKEN': csrfToken
    },
    body: JSON.stringify({items})
};

// Make the fetch request
const response = await fetch(fetchUrl, options);

Si nous voulons ajouter un mécanisme de délai d'attente pour récupérer, nous pouvons créer une promesse avec un délai d'attente qui déclenche un rejet. La promesse utilise Promise.race, pour exécuter plusieurs promesses et lorsque l'on termine par rejet ou résolution, arrête tout le reste.

// Timeout mechanism for fetch
const fetchWithTimeout = (url, options, timeout = 5000) => {
    return Promise.race([
        fetch(url, options),
        new Promise((_, reject) => setTimeout(() => reject(new Error('Request timed out')), timeout))
    ]);
};

// Make the fetch request
const response = await fetchWithTimeout(fetchUrl, options);

Voici un exemple réel avec des jetons CSRF

// Validate CSRF token
const csrfToken = document.querySelector('meta[name="csrf-token"]')?.content;
if (!csrfToken) {
    throw new Error('CSRF token not found in the document.');
}

// Prepare fetch options
const options = {
    method: method,
    headers: {
        'Content-Type': 'application/json',
        'Accept': 'application/json',
        'X-CSRF-TOKEN': csrfToken
    },
    body: JSON.stringify({items})
};

// Timeout mechanism for fetch
const fetchWithTimeout = (url, options, timeout = 5000) => {
    return Promise.race([
        fetch(url, options),
        new Promise((_, reject) => setTimeout(() => reject(new Error('Request timed out')), timeout))
    ]);
};

// Make the fetch request
const response = await fetchWithTimeout(fetchUrl, options);

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