首页 > web前端 > js教程 > 如何等待多个 JavaScript Promise 完成后再继续?

如何等待多个 JavaScript Promise 完成后再继续?

Barbara Streisand
发布: 2024-12-19 00:16:09
原创
391 人浏览过

How Can I Wait for Multiple JavaScript Promises to Finish Before Continuing?

在 JavaScript 中等待多个异步任务完成

问题:

你有一系列异步任务(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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板