


Comment garantir qu'un rappel est exécuté une fois toutes les opérations asynchrones terminées dans une boucle forEach ?
Nov 04, 2024 pm 02:17 PMRappel d'achèvement asynchrone forEach
Problème :
Comment exécuter un rappel lorsque toutes les opérations asynchrones dans une boucle forEach ont terminé ?
Solution :
1. Utilisation d'un compteur simple :
Initialisez un compteur itemsProcessed à 0. Incrémentez le compteur dans le rappel de chaque fonction asynchrone. Lorsque itemsProcessed atteint la longueur totale du tableau, invoquez le rappel « tout est terminé ».
2. Utilisation des promesses ES6 :
Créez un tableau d'objets Promise représentant chaque opération asynchrone à l'aide de Promise.all. Lorsque toutes les promesses seront terminées, le rappel final sera exécuté.
3. Utilisation d'une bibliothèque asynchrone :
Utilisez des bibliothèques asynchrones comme async pour fournir des mécanismes permettant d'exprimer des rappels d'achèvement asynchrones.
Exemple révisé (méthode Counter) :
<code class="javascript">function callback() { console.log("All done!"); } var itemsProcessed = 0; [1, 2, 3].forEach((item, index, array) => { asyncFunction(item, () => { itemsProcessed++; if (itemsProcessed === array.length) { callback(); } }); });</code>
Résultat attendu révisé :
3 done 1 done 2 done All done!
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Remplacer les caractères de chaîne en javascript

Tutoriel de configuration de l'API de recherche Google personnalisé

8 Superbes plugins de mise en page JQuery Page

Créez vos propres applications Web Ajax

Qu'est-ce que & # x27; ceci & # x27; en javascript?
