深入了解 JavaScript 中的 Promise 相关方法:all、race 和 allSettled

在 JavaScript 开发中,处理异步操作是很常见的需求。随着 ECMAScript 6(ES6)的引入,Promise 成为了处理异步操作的主要方式之一。而在 Promise 的方法中,Promise.all()Promise.race()Promise.allSettled() 是一些非常有用的工具,它们在处理异步操作时有各自的特点和用途。本文将介绍这三个方法的用法、示例以及区别,帮助读者更好地理解和应用它们。

Promise.all()

Promise.all() 方法接收一个 Promise 实例数组作为参数,并返回一个新的 Promise 实例。这个新的 Promise 实例会在传入的所有 Promise 实例都已经成功完成(resolved)时才会被解决(resolve),如果其中有任何一个 Promise 实例被拒绝(rejected),它就会立即将该拒绝的值传递给它的回调函数,并且 Promise.all() 返回的 Promise 实例也会被拒绝。

使用示例:

js 复制代码
const promise1 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise 1 已完成');
  }, 1000);
});

const promise2 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise 2 已完成');
  }, 2000);
});

Promise.all([promise1, promise2])
  .then(values => {
    console.log(values);
    // 输出:['Promise 1 已完成', 'Promise 2 已完成']
  })
  .catch(error => {
    console.error(error);
  });

Promise.race()

Promise.race() 方法接收一个 Promise 实例数组作为参数,返回一个新的 Promise 实例。这个新的 Promise 实例会在传入的 Promise 实例中有一个率先解决(resolve)或拒绝(reject)时解决或拒绝,并且它的状态和值会与率先解决或拒绝的 Promise 相同。通常用于设置超时操作,或者在多个请求中只需要获取其中一个结果的情况下。

使用示例:

js 复制代码
const promise1 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise 1 已完成');
  }, 2000);
});

const promise2 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise 2 已完成');
  }, 1000);
});

Promise.race([promise1, promise2])
  .then(value => {
    console.log(value);
    // 输出:'Promise 2 已完成',因为 promise2 较快完成
  })
  .catch(error => {
    console.error(error);
  });

Promise.allSettled()

Promise.allSettled() 方法接收一个 Promise 实例数组作为参数,返回一个新的 Promise 实例。这个新的 Promise 实例会在传入的所有 Promise 实例都已经解决(无论是成功还是失败)后解决,并返回一个包含所有 Promise 结果的数组。不同于 Promise.all(),它不会在有 Promise 被拒绝时立即拒绝整个 Promise 链,而是等待所有 Promise 结束后返回结果。

使用示例:

js 复制代码
const promise1 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise 1 已完成');
  }, 2000);
});

const promise2 = new Promise((resolve, reject) => {
  setTimeout(() => {
    reject('Promise 2 失败了');
  }, 1000);
});

Promise.allSettled([promise1, promise2])
  .then(results => {
    console.log(results);
    /* 输出:
    [
      { status: 'fulfilled', value: 'Promise 1 已完成' },
      { status: 'rejected', reason: 'Promise 2 失败了' }
    ]
    */
  });

区别与总结

  • Promise.all() 会在所有 Promise 实例成功完成时才成功,一旦有一个失败就会立即失败。
  • Promise.race() 会在任何一个 Promise 实例率先成功或失败时返回结果。
  • Promise.allSettled() 则会等待所有 Promise 实例结束后返回结果,无论是成功还是失败。

这三个方法各有特点,根据实际需求选择合适的方法来处理异步操作,可以提高代码的可读性和性能。

相关推荐
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦2 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
开发者每周简报2 小时前
网海三部曲·无名宗师传
javascript·人工智能
喵个咪2 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
摆烂大大王4 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao4 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色4 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆4 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6
lichenyang4534 小时前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端
IT_陈寒5 小时前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端