前端的Promise的方法all,race,any

🔥 深入解析Promise并发控制:allanyrace三大方法实战手册


Promise的核心作用

JavaScript作为单线程语言,为避免同步代码阻塞影响用户体验,采用异步机制处理非即时任务。主线程执行同步代码时,异步任务(如Promise)会被推入消息队列 。其中,Promise.then()产生的微任务(Microtask)​ ​ 具有最高优先级,优先于宏任务(如setTimeout)执行,从而高效管理异步流程。


​**Promise.all():全成功才成功**​

特点​:

  • 接收Promise数组,返回新Promise
  • 全成功:返回结果数组(按输入顺序)
  • 一票否决:任一失败则立即拒绝,返回首个错误

适用场景 ​:

多个强依赖的并行任务需全部成功(如同时请求多个API)。

代码实现​:

js 复制代码
Promise.myAll = function(promises) {
  let results = []; // 存储结果(保证顺序)
  let completed = 0; // 完成计数器
  return new Promise((resolve, reject) => {
    promises.forEach((promise, index) => {
      Promise.resolve(promise) // 处理非Promise值
        .then(value => {
          results[index] = value; // 按索引存入结果
          completed++;
          if (completed === promises.length) {
            resolve(results); // 全部成功时返回结果数组
          }
        })
        .catch(reject); // 任一失败立即拒绝
    });
  });
};

​**Promise.any():一成功就成功**​

特点​:

  • 接收Promise数组,返回新Promise
  • 一票通过:任一成功则立即返回该结果
  • 全败才拒 :全部失败时拒绝,返回AggregateError(含所有错误)

适用场景 ​:

容错场景(如从多个备用源获取最快可用数据)。

代码实现​:

javascript 复制代码
javascript
javascript
复制
Promise.myAny = function(promises) {
  let errors = []; // 存储所有错误
  let failed = 0; // 失败计数器
  return new Promise((resolve, reject) => {
    promises.forEach((promise, index) => {
      Promise.resolve(promise)
        .then(resolve) // 任一成功立即解决
        .catch(err => {
          errors[index] = err; // 按索引记录错误
          failed++;
          if (failed === promises.length) {
            // 全部失败时返回聚合错误
            reject(new AggregateError(errors, "All promises were rejected"));
          }
        });
    });
  });
};

​**Promise.race():先到先得**​

特点​:

  • 接收Promise数组,返回新Promise
  • 速度竞赛:采用首个敲定状态(无论成功/失败)的结果

适用场景 ​:

超时控制(如网络请求限时响应)。

代码实现​:

javascript 复制代码
Promise.myRace = function(promises) {
  return new Promise((resolve, reject) => {
    for (const promise of promises) { // 遍历可迭代对象
      Promise.resolve(promise) // 处理非Promise值
        .then(resolve) // 首个成功则解决
        .catch(reject); // 首个失败则拒绝
    }
  });
};

三大方法对比总结

方法 解决条件 拒绝条件 适用场景
Promise.all 所有Promise成功 任一Promise失败 强依赖的并行任务(如多API)
Promise.any 任一Promise成功 所有Promise失败 容错处理(如多数据源择优)
Promise.race 首个Promise状态敲定 首个Promise状态敲定 竞速场景(如超时控制)

关键提示​:

  1. Promise.all 的"快速失败"特性可能导致部分异步操作未终止
  2. Promise.any 的聚合错误(AggregateError)需特殊处理
  3. 空数组输入:all 立即解决,race 永久挂起,any 拒绝
相关推荐
冻感糕人~9 分钟前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
程序员agions12 分钟前
2026年,“配置工程师“终于死绝了
前端·程序人生
alice--小文子19 分钟前
cursor-mcp工具使用
java·服务器·前端
晚霞的不甘28 分钟前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小迷糊的学习记录37 分钟前
0.1 + 0.2 不等于 0.3
前端·javascript·面试
空&白1 小时前
vue暗黑模式
javascript·vue.js
梦帮科技1 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头2 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多2 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-2 小时前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript