Promise.allSettled适合处理多个异步操作,等待所有完成(无论成功或失败),返回结果数组包含每个Promise的状态和值或错误原因,不因单个失败而中断整体流程。

当需要处理多个异步操作,并且希望等待它们全部完成,不管成功或失败时,Promise.allSettled 是最合适的方法。它与 Promise.all 不同,不会因为其中一个 Promise 被拒绝而提前终止。
Promise.allSettled 的基本理解
该方法接收一个 Promise 数组作为参数,返回一个新的 Promise,这个 Promise 在所有输入的 Promise 都“完成”(无论是 fulfilled 还是 rejected)后才会被 settled。
返回的结果是一个对象数组,每个对象描述对应 Promise 的执行结果:
- 如果成功:{ status: 'fulfilled', value: 结果值 }
- 如果失败:{ status: 'rejected', reason: 错误原因 }
这意味着你可以安全地获取每个任务的最终状态,无需担心异常中断整个流程。
立即学习“Java免费学习笔记(深入)”;
适用场景和使用示例
当你发起多个独立请求,比如从不同 API 获取用户数据、商品信息、配置项等,其中某一个失败不应影响你处理其他成功的响应,这时就非常适合使用 allSettled。
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
const promises = [
fetch('/api/user').then(res => res.json()),
fetch('/api/products').then(res => res.json()),
Promise.reject('网络超时')
];
Promise.allSettled(promises).then(results => {
results.forEach((result, index) => {
if (result.status === 'fulfilled') {
console.log(`请求 ${index} 成功:`, result.value);
} else {
console.error(`请求 ${index} 失败:`, result.reason);
}
});
});
上面代码中,即使第三个 Promise 被拒绝,前面两个的成功结果依然可以正常处理。
与 Promise.all 和 Promise.race 的对比
Promise.all:只要有一个 Promise 被 reject,整体就立即 reject,适用于“全成功才算成功”的场景。
Promise.race:只取第一个 settled 的 Promise,不管是 resolve 还是 reject,适合做超时控制。
Promise.allSettled:关注所有结果,不因个别失败而中断,适合并行任务的批量结果收集。
基本上就这些。在需要稳健处理多个异步任务结果时,allSettled 提供了更全面的信息和更高的容错性。不复杂但容易忽略的是:记得检查每个结果的 status 字段,再决定如何处理 value 或 reason。









