Promise.all 和 Promise.allSettled 详解

这两个都是 Promise 并发处理 的核心 API,用来同时执行多个 Promise ,最大的区别是:对失败的处理方式完全不同

Promise.all必须全部成功 ,一个失败就直接整体失败(短路失败

Promise.allSettled无论成功失败都等到底 ,返回所有结果(全部完成


1. Promise.all()

特点:

  • 接收一个 Promise 数组
  • 所有 Promise 都成功 → 返回成功结果数组
  • 只要有一个失败 → 立即触发失败,不会等待其他 Promise
  • 适合:必须全部成功才能继续的场景(比如批量请求数据缺一不可)
javascript 复制代码
const p1 = Promise.resolve('成功1');
const p2 = Promise.resolve('成功2');
const p3 = Promise.reject('失败3');

// 全部成功
Promise.all([p1, p2])
  .then(res => console.log('all 成功:', res)) 
  .catch(err => console.log('all 失败:', err));

// 有一个失败 → 直接整体失败
Promise.all([p1, p2, p3])
  .then(res => console.log('all 成功:', res))
  .catch(err => console.log('all 失败:', err)); 

2. Promise.allSettled()

特点:

  • 接收一个 Promise 数组
  • 等待所有 Promise 执行完成(不管成功 / 失败)
  • 永远不会走到 catch ,返回一个结果对象数组
  • 每个结果对象包含:
    • status: "fulfilled" + value:成功
    • status: "rejected" + reason:失败
  • 适合:需要知道每一个请求的结果(比如批量上传、批量校验)
javascript 复制代码
const p1 = Promise.resolve('成功1');
const p2 = Promise.reject('失败2');

Promise.allSettled([p1, p2])
  .then(results => {
    console.log('allSettled 结果:', results);
  });


//    [
//      { status: 'fulfilled', value: '成功1' },
//      { status: 'rejected', reason: '失败2' }
//    ]

3. 核心区别对比表

特性 Promise.all Promise.allSettled
失败处理 一个失败 → 整体失败 全部执行完,返回所有结果
返回值 成功数据数组 / 失败原因 固定返回结果对象数组
状态 要么全成功,要么直接失败 永远是成功状态
适用场景 缺一不可、强依赖 收集所有结果、不关心部分失败

4. 实际使用场景

用 Promise.all

  • 表单提交前多个接口必须全部成功
  • 页面初始化必须加载完所有资源
  • 批量创建数据必须全部创建成功

用 Promise.allSettled

  • 批量上传文件(部分失败不影响其他)
  • 批量获取用户信息(个别用户不存在也要展示其他)
  • 需要统计成功 / 失败数量的任务

总结

  1. 缺一不可 → 用 Promise.all
  2. 全部要结果 → 用 Promise.allSettled
  3. all短路失败allSettled等待到底
相关推荐
暗冰ཏོ1 小时前
前端数据大屏开发完整指南:Vue3 + ECharts 自适应可视化实战
前端·javascript·echarts·数据大屏·大屏端
陈_杨1 小时前
鸿蒙APP开发-带你了解单块酷APP参数管理的功能
前端·javascript
moMo1 小时前
# 从重置样式到 BEM 命名:写一个微信的按钮
前端·css
2301_815645381 小时前
saas 一面
前端·面经
无风听海1 小时前
OAuth 2.0 Scope 的使用与设计规划
前端
2501_916008891 小时前
全面解析常用Web前端开发工具:编辑器、调试工具、性能分析器与框架
android·前端·ios·小程序·uni-app·编辑器·iphone
暗夜猎手-大魔王1 小时前
转载--Hermes Agent 08 | Agent 的自我进化:nudge、后台审查与轨迹数据
java·前端·人工智能
IT_陈寒1 小时前
Redis集群节点迁移把我坑惨了,这个坑你得提前绕开
前端·人工智能·后端
新酱爱学习2 小时前
手搓 10 个 Skill 踩出来的坑,我做成了一套工程化工具链
前端·人工智能·agent