首頁 >web前端 >js教程 >如何同時使用 Array.map 和 async/await 來正確處理 Promise?

如何同時使用 Array.map 和 async/await 來正確處理 Promise?

Susan Sarandon
Susan Sarandon原創
2024-12-14 11:47:18914瀏覽

How Can I Use `Array.map` and `async/await` Together to Process Promises Correctly?

Array.map 和Async/Await:解決Promise 相容性

下面的程式碼片段旨在利用Array.map 和async/await ,它會觸發錯誤:

var arr = [1,2,3,4,5];

var results: number[] = await arr.map(async (item): Promise<number> => {
        await callAsynchronousOperation(item);
        return item + 1;
    });

錯誤源自於嘗試等待一連串的Promise 而非單一 Promise。然而,快速的解決方案在於在等待其解析之前使用 Promise.all 將 Promise 陣列轉換為單獨的 Promise。

var arr = [1, 2, 3, 4, 5];

var results: number[] = await Promise.all(arr.map(async (item): Promise<number> => {
    await callAsynchronousOperation(item);
    return item + 1;
}));

以上是如何同時使用 Array.map 和 async/await 來正確處理 Promise?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn