在处理多个并发请求时,一般会用Promise.all()方法。
Promise.all方法用于将多个 Promise 实例,包装成一个新的 Promise 实例
语法:
const p = Promise.all([p1, p2, p3]);
Promise.all() 方法接收一个 promise 的 iterable 类型(注:Array,Map,Set 都属于 ES6 的 iterable 类型)的输入,并且只返回一个Promise实例, 那个输入的所有 promise 的 resolve 回调的结果是一个数组。这个Promise的 resolve 回调执行是在所有输入的 promise 的 resolve 回调都结束,或者输入的 iterable 里没有 promise 了的时候。它的 reject 回调执行是,只要任何一个输入的 promise 的 reject 回调执行或者输入不合法的 promise 就会立即抛出错误,并且 reject 的是第一个抛出的错误信息。
如何让Promise.all在抛出异常后依然有效?
在promise.all队列中,使用map过滤每一个promise任务,其中任意一个报错后,return一个返回值,确保promise能正常执行走到.then当中
var p1 = new Promise((resolve, reject) => {
resolve('p1');
});
var p2 = new Promise((resolve, reject) => {
resolve('p2');
});
var p3 = new Promise((resolve, reject) => {
reject('p3');
});
Promise.all([p1, p2, p3].map(p => p.catch(e => '出错啦!' )))
.then(res => {
console.log(res);
}).catch(err => {
console.log(err);
})
使用 Promise.allSettled 替代 Promise.all()。
Promise.allSettled()方法返回一个在所有给定的 promise 都已经fulfilled或rejected后的 promise,并带有一个对象数组,每个对象都描述了对应的 promise 结果。
总结
Promise.all() 更适合彼此相互依赖或者在其中任何一个reject时立即结束。
Promise.allSettled()更适合多个彼此不依赖的异步任务成功完成时,或者想知道每个promise的结果。