Promise.all错误处理

本文介绍使用 JavaScript 的 Promise.all 方法处理并发请求时如何正确捕捉并处理失败的情况,通过示例代码展示了当其中一个请求失败时如何依然获取到其他成功请求的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

function requestFirst() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            resolve('第一个请求返回');
        }, 1000)
    })
}
function requestSecond() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            resolve('第二个请求返回');
        }, 2000)
    })
}
function requestThird() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            reject('第三个请求返回');
        }, 3000)
    })
}

let requestArr = [requestFirst(), requestSecond(), requestThird()]
Promise.all(requestArr).then(res => {
    console.log('结果1', res);
}).catch(err => {
    console.log('错误1', err);
})

// 错误1 第三个请求返回


// Promise.all错误处理

async function handleAllFunc(fun){
    try{
        let res = await fun
        return res
    }catch(err){
        return err
    }
}

Promise.all(requestArr.map(item => handleAllFunc(item))).then(res => {
    console.log('结果', res);
}).catch(err => {
    console.log('错误', err);
})

// 结果[“第一个请求返回”, “第二个请求返回”, “第三个请求返回”]

### 正确使用 `Promise.all` 嵌套 当处理多个并行操作时,可以利用 `Promise.all` 来等待一组异步操作完成。如果需要在一个 `Promise.all` 调用内部再启动另一组并发任务,则可以通过返回一个新的 `Promise.all` 实现这一点。 ```javascript const outerPromises = [ new Promise((resolve) => setTimeout(() => resolve('one'), 100)), new Promise(async (resolve) => { const innerResults = await Promise.all([ new Promise(resolve => setTimeout(() => resolve(2), 50)), new Promise(resolve => setTimeout(() => resolve(3), 75)) ]); resolve(innerResults); }), new Promise((resolve) => setTimeout(() => resolve('three'), 150)) ]; // 执行外部的 Promise.all 并获取最终结果 Promise.all(outerPromises).then(results => console.log(results)); ``` 上述代码展示了如何在外层 `Promise.all` 中嵌入另一个 `Promise.all`。外层数组中的第二个元素是一个立即解析为内层 `Promise.all` 结果的新承诺对象[^1]。 #### 注意事项 - **错误传播**:任何一层内的失败都会导致整个链路中断。因此建议在每一级都加入 `.catch()` 处理可能发生的异常情况。 - **性能考虑**:虽然理论上可以在任意深度上进行嵌套调用,但这可能会增加复杂度以及潜在影响到程序的整体响应时间。应尽量减少不必要的层次结构来保持良好的可读性和维护性。 - **上下文管理**:对于像 Node.js 这样的环境,在版本8及以上中,`.then()` 或者 `.catch()` 方法被触发时会保留创建它们所在的域(context),这有助于调试和追踪问题所在位置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值