Maison  >  Article  >  interface Web  >  Comment puis-je exécuter des fonctions asynchrones simultanément en JavaScript ?

Comment puis-je exécuter des fonctions asynchrones simultanément en JavaScript ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-11-20 04:33:01766parcourir

How Can I Execute Async Functions Concurrently in JavaScript?

Exécuter des fonctions asynchrones simultanément

Dans ES7/ES2016, l'utilisation de plusieurs instructions wait n'exécute pas les fonctions en parallèle. Au lieu de cela, ils sont exécutés séquentiellement, un peu comme enchaîner .then() avec des promesses.

Exemple :

await someCall();
await anotherCall();

Dans cet exemple, anotherCall() ne sera que appelé une fois someCall() terminé.

Parallélisation des appels de fonctions asynchrones

Pour exécuter des fonctions asynchrones en parallèle, il existe quelques options :

Utiliser Promise.all()

L'approche la plus simple dans Node.js consiste à utiliser Promise.all() pour encapsuler les fonctions asynchrones que vous souhaitez exécuter simultanément :

await Promise.all([someCall(), anotherCall()]);

Cela créera un promesse unique qui représente l'achèvement de toutes les promesses d'entrée.

Stockage des résultats

Si vous devez stocker les résultats, vous pouvez utiliser la déstructuration dans l'instruction wait :

let [someResult, anotherResult] = await Promise.all([someCall(), anotherCall()]);

Remarque sur la gestion des erreurs

Promise.all échouera rapidement. Cela signifie que si l'une des promesses d'entrée est rejetée, l'ensemble de l'opération sera rejetée avec cette erreur.

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