问题:
你有一系列异步任务(promises) )并且仅当所有代码块都已执行时才需要执行已完成。
解决方案:
使用 Promise.all 将所有 Promise 收集到一个数组中并等待其解决或
实现:
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 函数:
function doSomeAsyncStuff() { return new Promise((resolve, reject) => { const editor = generateCKEditor(); editor.on('instanceReady', (evt) => { doSomeStuff(); resolve(true); }) }); }
示例:
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();
以上是如何等待多个 JavaScript Promise 完成后再继续?的详细内容。更多信息请关注PHP中文网其他相关文章!