前端的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 拒绝
相关推荐
kyriewen2 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒3 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马3 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮3 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦3 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer4 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队4 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY4 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_4 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏4 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端