首頁 > web前端 > js教程 > 如何暫停執行直到多個 Promise 解決?

如何暫停執行直到多個 Promise 解決?

Patricia Arquette
發布: 2024-12-27 03:02:13
原創
531 人瀏覽過

How to Pause Execution Until Multiple Promises Resolve?

返回多個 Promise 並暫停執行直到全部完成

您需要使用返回 Promise 的方法來處理多個非同步操作。這些操作完成後,只有當所有 Promise 都已解決時,您才需要執行另一組程式碼。

doSomeAsyncStuff() 中的 Promise

您的 doSomeAsyncStuff() 函數需要傳回一個 Promise。這個Promise 反映了非同步任務的完成:

function doSomeAsyncStuff() {
    return new Promise((resolve, reject) => {
        var editor = generateCKEditor();
        editor.on('instanceReady', () => {
            doSomeStuff();
            resolve(true);
        });
    });
}
登入後複製

使用Promise.all()

一旦你的非同步函數傳回一個Promise,你就可以使用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((error) => {
        // Handle errors here
    });
登入後複製

範例

以下是一個在所有五個非同步任務完成後記錄訊息的範例:

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((error) => {
            // Handle errors here
        });
}

test();
登入後複製

以上是如何暫停執行直到多個 Promise 解決?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板