一次性帮你搞定 Promise 的四个静态方法

长篇大论的原文和引用我就不贴了,直接上干货。

1. Promise.all():一荣俱荣,一损俱损

  • 一句话概括:一荣俱荣,一损俱损 (all one rope mazha) 。
  • 核心条件 :它等待传入数组中的所有 Promise 都成功兑现 (fulfilled) 后才完成。只要其中有一个 Promise 失败 (rejected) ,Promise.all() 就会立即失败,并返回第一个失败的原因,忽略其余的结果。
  • 返回值 :按传入的Promise 数组顺序返回结果。
  • 适用场景 :当所有任务都是关键的,并且任何一个失败都会导致整个操作失去意义时。例如,加载页面正常运行所必需的多个关键资源,相互依赖的两个资源,同步请求多个接口等。

2. Promise.allSettled():活要见人,死要见尸

  • 一句话概括:活要见人,死要见尸 (deadline) 。
  • 核心条件 :它等待传入数组中的所有 Promise 都达到"敲定" (settled,无论成功或失败) 状态后才完成。它永远不会失败,总是返回一个数组,其中包含了每个 Promise 的最终结果 (状态、值或原因) 。
  • 返回值 :按传入的Promise 数组顺序返回结果。但是注意,有失败结果也会包含在其中
  • 适用场景:在处理批量任务时,即使部分任务失败,仍需要知道所有任务的最终结果,以便进行后续处理。例如,一个批量发送邮件的接口,即使部分邮件发送失败,也要记录所有邮件的最终发送结果。
javascript 复制代码
Promise.allSettled([Promise.resolve("活着的敌酋"), Promise.reject("死了的敌酋")]).then((res) => {
  console.log("活要见人,死要见尸", res);
});

3. Promise.race():一马当先,先登之士

  • 一句话概括:一马当先,先登之士 (ao ao fast) 。
  • 核心条件 :它等待传入数组中的第一个 Promise 达到 settled 状态时,就立即完成,无论成功还是失败 (就问你快不快吧) 。它会忽略数组中的其他所有 Promise
  • 适用场景 :当需要实现超时控制 或在多个数据源中竞争 获取最快结果时。例如,给一个网络请求设置超时限制,setTimeout 设置一个超时时间,如果超时了,就返回一个错误,和请求接口一同传入Promise.race([request, timeout])中,或者 planB 和 planA 一同传入Promise.race([planA, planB])中。
javascript 复制代码
const promise1 = new Promise((resolve) => {
  setTimeout(() => {
    resolve("新款电动三轮车");
  }, 1000);
});
const promise2 = new Promise((resolve, reject) => {
  setTimeout(reject, 100, "老款A8");
});

Promise.race([promise1, promise2])
  .then((values) => {
    console.log("老A8不是A8?", values);
  })
  .catch((error) => {
    console.log("就问你是不是", error);
  });

4. Promise.any():谁来都行,好交朋友

  • 一句话概括:谁来都行,好交朋友 (all just gemen) 。
  • 核心条件 :它等待传入数组中的第一个 Promise 成功 (fulfilled) 时,就立即完成。只有当数组中的所有 Promise 都失败 (rejected) 时,它才会以一个 AggregateError 失败。
  • 适用场景 :当有多个冗余的数据源,而只需要其中任意一个成功的结果时。例如,从多个备份服务器获取数据,只要其中一个成功了,就返回结果,谁来都行,就跟郭老师说王寡妇好交朋友一个道理。
javascript 复制代码
const promises = [Promise.reject(new Error("张裁缝")), Promise.reject(new Error("李铁匠")), Promise.resolve("赵屠户")];

Promise.any(promises)
  .then((value) => {
    console.log("成功和王寡妇交朋友的时:", value); // '赵屠户'
  })
  .catch((error) => {
    // 只有当所有 Promise 都失败时才会执行
    console.log(error instanceof AggregateError); // true
    console.log(error.errors); // [Error('失败1'), Error('失败2')]
  });

总结

这四个 Promise 静态方法的核心都是监听器 (他们并不发送所谓的并行请求,只是监听请求的状态),它们都用于观察一组已经开始执行 的异步任务的状态。它们之间唯一的区别,就在于它们监听并完成的条件不同。

  • Promise.all():一荣俱荣,一损俱损
  • Promise.allSettled():活要见人,死要见尸
  • Promise.race():一马当先,先登之士
  • Promise.any():谁来都行,好交朋友

参考资料 MDN Promise

bu:lichonglou

相关推荐
啦啦91188613 分钟前
【版本更新】Edge 浏览器 v142.0.3595.94 绿色增强版+官方安装包
前端·edge
蚂蚁集团数据体验技术31 分钟前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
LQW_home40 分钟前
前端展示 接受springboot Flux数据demo
前端·css·css3
q***d1731 小时前
前端增强现实案例
前端·ar
IT_陈寒1 小时前
Vite 3.0 重磅升级:5个你必须掌握的优化技巧和实战应用
前端·人工智能·后端
JarvanMo1 小时前
Flutter 3.38 + Firebase:2025 年开发者必看的新变化
前端
Lethehong1 小时前
简历优化大师:基于React与AI技术的智能简历优化系统开发实践
前端·人工智能·react.js·kimi k2·蓝耘元生代·蓝耘maas
华仔啊1 小时前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript
鹏北海2 小时前
多标签页登录状态同步:一个简单而有效的解决方案
前端·面试·架构
_AaronWong2 小时前
基于 Vue 3 的屏幕音频捕获实现:从原理到实践
前端·vue.js·音视频开发