首頁 > web前端 > js教程 > 如何等待多個 JavaScript Promise 完成後再繼續?

如何等待多個 JavaScript Promise 完成後再繼續?

Barbara Streisand
發布: 2024-12-19 00:16:09
原創
386 人瀏覽過

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

在JavaScript 中等待多個非同步任務完成

問題:

你有一系列非同步任務(promises🎜>

你有一系列非同步任務(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
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板