Promise.all捕获错误

Promise.all默认只要有一个错误就直接返回错误。promise.all中任何一个promise 出现错误的时候都会执行reject,导致其它正常返回的数据也无法使用

Promise.all([
	Promise.resolve(1), 
	Promise.reject('err'), 
	Promise.resolve(2)
]).then(res => {
	console.log(res)
}).catch(err => {
	console.log('error', err)
})

// 结果返回: error err

如果我们数组有某些错误但不影响其他结果返回,应该对每项promise进行捕获。

Promise.all([
	Promise.resolve(1), 
	Promise.reject('err'), 
	Promise.resolve(2)].map(item => {
		return item.catch(err => {
			console.log('item error', err)
		})
	})
).then(res => {
	console.log(res)
}).catch(err => {
	console.log('error', err)
})
// 结果返回:
// item error err
//  [1, undefined, 2]

这样就可以实现不管某个出现问题,不影响最后结果的返回。

Promise.all 简版实践原理

function promiseAll(promises){
    return new Promise((resolve,reject) => {
        if (!Array.isArray(promises)) {
            return reject(new TypeError("argument must be anarray"))
        }
        let countNum=0;
        let promiseNum=promises.length;
        let resolvedvalue=new Array(promiseNum);
        for (let i=0; i<promiseNum; i++) {
            Promise.resolve(promises[i]).then(value =>{
                countNum++;
                resolvedvalue[i]=value;
                if(countNum===promiseNum){
                    return resolve(resolvedvalue)
                }
            },reason => {
                return reject(reason)
            })
        }
    })
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`Promise.all` 是一个非常有用的方法,它可以同时处理多个 Promise 对象,并在所有 Promise 都 resolved 后返回一个新的 Promise 对象。然而,有一些坑需要注意: 1. **一旦有一个 Promise rejected,Promise.all 就会立即停止并返回一个 rejected Promise**:如果其中一个 Promise 被 rejected,Promise.all 将立即停止执行并返回一个 rejected Promise。这意味着,即使其他的 Promise 已经 resolved,它们的结果也将被忽略。因此,在使用 Promise.all 时,请确保你对每个 Promise 都进行了适当的错误处理。 2. **Promise.all 返回顺序与输入顺序一致**:Promise.all 返回的结果数组将按照输入数组中的顺序排列。这意味着,如果你传入的 Promise 数组的顺序很重要,那么你可以根据返回的结果数组来获取对应的结果。 3. **如果传入的不是 Promise 对象,Promise.all 会自动将其转换为 resolved 状态**:当你传入的数组中包含非 Promise 对象时,Promise.all 会自动将它们转换为 resolved 状态,并将它们的值作为结果数组中的对应值。这可能会导致一些意外行为,因此在使用 Promise.all 时,请确保你传入的是合适的 Promise 对象。 4. **记得处理 Promise.all 返回的 Promise**:因为 Promise.all 返回一个新的 Promise 对象,所以你需要使用 `.then()` 或 `.catch()` 来处理它的结果或错误。如果你忘记处理它,可能会导致未捕获Promise rejection 错误。 希望这些信息对你有帮助!如果你有更多关于 Promise.all 的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值