问答题616/1593遍历一个任意长度的list中的元素并依次创建异步任务,如何获取所有任务的执行结果?

难度:
2022-08-07 创建

参考答案:

看到这个题目,大家首先想到的是 Promise.all 或者 Promise.allSettled

  • Promise.all

Promise.all 需要传入一个数组,数组中的元素都是 Promise 对象。当这些对象都执行成功时,则 all 对应的 promise 也成功,且执行 then 中的成功回调。如果有一个失败了,则 all 对应的 promise 失败,且失败时只能获得第一个失败 Promise 的数据。

1const p1 = new Promise((resolve, reject) => { 2 resolve('成功了') 3}) 4const p2 = Promise.resolve('success') 5const p3 = Promise.reject('失败') 6 7Promise.all([p1, p2]).then((result) => { 8 console.log(result) //["成功了", "success"] 9}).catch((error) => { 10 //未被调用 11}) 12 13Promise.all([p1, p3, p2]).then((result) => { 14 //未被调用 15}).catch((error) => { 16 console.log(error) //"失败" 17});
  • Promise.allSettled

Promise.allSettled() 可用于并行执行独立的异步操作,并收集这些操作的结果。

Promise.allSettled() 方法返回一个在所有给定的 promise 都已经 fulfilled 或 rejected 后的 promise,并带有一个对象数组,每个对象表示对应的 promise 结果。

1Promise.allSettled([p1, p2, p3]) 2.then(values => { 3 console.log(values) 4})

最近更新时间:2024-07-20

赞赏支持

预览

题库维护不易,您的支持就是我们最大的动力!