Maison >interface Web >js tutoriel >Comment puis-je attendre la fin de plusieurs promesses JavaScript avant de continuer ?
Problème :
Vous avez une série de tâches asynchrones (promesses ) et doivent exécuter un bloc de code uniquement lorsque tous ont été terminé.
Solution :
Utilisez Promise.all pour rassembler toutes les promesses dans un seul tableau et attendre sa résolution ou son rejet.
Mise en œuvre :
const promises = []; for (let i = 0; i < 5; i++) { promises.push(doSomeAsyncStuff()); } Promise.all(promises) .then(() => { for (let i = 0; i < 5; i++) { doSomeStuffOnlyWhenTheAsyncStuffIsFinish(); } }) .catch((e) => { // Handle errors here });
DoSomeAsyncStuff révisé fonction :
function doSomeAsyncStuff() { return new Promise((resolve, reject) => { const editor = generateCKEditor(); editor.on('instanceReady', (evt) => { doSomeStuff(); resolve(true); }) }); }
Exemple :
function doSomethingAsync(value) { return new Promise((resolve) => { setTimeout(() => { console.log("Resolving " + value); resolve(value); }, Math.floor(Math.random() * 1000)); }); } function test() { const promises = []; for (let i = 0; i < 5; i++) { promises.push(doSomethingAsync(i)); } Promise.all(promises) .then((results) => { console.log("All done", results); }) .catch((e) => { // Handle errors here }); } test();
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!