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等待到底
相关推荐
光影少年14 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
用户9004633704014 小时前
用Gemini搞定Vue报错和语法异常的问题
vue.js
糖拌西瓜皮14 小时前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮14 小时前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js
糖拌西瓜皮14 小时前
Express框架快速上手:中间件、路由与错误处理
javascript·node.js
禅思院16 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮17 小时前
深入理解Loop Engineering
前端·后端
半个落月17 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
风骏时光牛马17 小时前
VHDL十大经典基础功能设计实例代码合集
前端
小兔崽子去哪了17 小时前
Vue3 + Pinia 集成 IGV.js 实现 BAM 文件在线浏览
javascript·vue.js·后端