開始 一文搞懂 Promise 新 Api allSettled 的用法和 all 區別,以及如何在不支持新特性的環境下實現一個 Polyfill allSettled 的用法 const runAllSettled = async () => { const successPromise = Pr ...
開始
一文搞懂 Promise 新 Api allSettled
的用法和 all
區別,以及如何在不支持新特性的環境下實現一個 Polyfill
allSettled 的用法
const runAllSettled = async () => {
const successPromise = Promise.resolve('success') // 一個正常返回的 Promise
const failPromise = Promise.reject('fail') // 一個異常返回的 Promise
// 使用 allSettled
const settiled = await Promise.allSettled([successPromise, failPromise, undefined, null])
console.log(settiled)
/* 輸出結果如下
[
{status: 'fulfilled', value: 'success'},
{status: 'rejected', reason: 'fail'},
{status: 'fulfilled', value: undefined},
{status: 'fulfilled', value: null},
]
*/
}
runAllSettled()
- 返回一個數組,每一個元素都是一個對象,裡面必然包含
status
屬性 status
屬性只會有兩個值,fulfilled
或者rejected
,非黑即白的既視感allSettled
總是走then
的,也就是併發的 Promise 出現reject
也不會走catch
,需要自行遍歷返回的數組,判斷status
來做錯誤捕獲- 對象中還有另外兩個屬性,
value
和reason
。根據 promise 的狀態返回,如果成功返回,即為value
,反之為reason
- 更詳細的 TS 類型在這裡
lib.es2020.promise.d.ts
all 的用法
- all 的用法就不再詳細贅述,可前往 MDN 查看
區別
功 能 | Promise.all |
Promise.allSettled |
---|---|---|
併發 | ✅ | ✅ |
併發Promise中出現 reject 是否還走 then |
❌ | ✅ |
在不支持 Promise.allSettled
新特性的環境下實現一個 Polyfill
// 通過 Promise.all 實現 Promise.allSettled
if (!Promise.allSettled) {
Promise.allSettled = function (promises) {
return Promise.all(
promises.map((p) =>
Promise.resolve(p).then(
(value) => ({
status: "fulfilled",
value,
}),
(reason) => ({
status: "rejected",
reason,
})
)
)
);
};
}
當下敲的每一個字母,都將在未來的某天回報於自己~