JavaScript 的 Promise 对象和 Promise.all 方法的使用

JavaScript 中的 Promise 对象

什么是 Promise?

Promise 是一种用于处理异步操作的对象。它代表一个尚未完成但预计将来会完成的操作及其结果。

主要特点:
  1. 状态:

    • Pending(进行中): 初始状态,既未成功,也未失败。
    • Fulfilled(已成功): 操作成功完成。
    • Rejected(已失败): 操作失败。
  2. 方法:

    • .then(onFulfilled[, onRejected]): 注册回调函数,分别在 Promise 成功或失败时调用。
    • .catch(onRejected): 特殊形式的.then(),仅注册拒绝情况下的回调。
    • .finally(onFinally): 无论 Promise 结果如何都会执行的回调。
  3. 链式调用

    javascript 复制代码
    fetch(url)
        .then(response => response.json())
        .then(data => console.log(data))
        .catch(error => console.error('Fetch failed:', error));
  4. 静态方法:

    • Promise.resolve(value) 创建一个已解决的 Promise 实例。
    • Promise.reject(reason) 创建一个已拒绝的 Promise 实例。

使用 Promise.all

Promise.all(iterable) 方法接收一组 Promise 并返回一个新的 Promise。当所有的 Promise 都成功完成后,新的 Promise 将被解决;如果有任何一个 Promise 被拒绝,则整个组合也会立刻被拒绝。

特性:

  1. 返回一个新 Promise。
  2. 当所有提供的 Promises 全部满足时,返回的 Promise 才会被解决。
  3. 如果其中一个 Promise 被拒绝,返回的新 Promise 会立即进入 rejected 状态,并携带第一个被拒绝的原因作为其结果。
javascript 复制代码
const promise1 = new Promise((resolve, reject) => setTimeout(() => resolve(1), 1000));
const promise2 = new Promise((resolve, reject) => setTimeout(() => resolve(2), 2000));

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

Promise.allSettled

Promise.allSettled(iterable) 方法同样接收一组 Promise 并返回一个新的 Promise。当所有的 Promise 都结束(无论是成功还是失败)时,新的 Promise 才会被解决。

特性:

  1. 返回一个新 Promise。
  2. 包含所有 Promise 结果的一个数组,不论它们是成功的还是失败的。
  3. 每个元素都是一个对象,表示对应的 Promise 的最终状态(fulfilled 或 rejected),并带有相应的值或理由。
javascript 复制代码
const promise1 = new Promise((resolve, reject) => setTimeout(() => resolve(1), 1000));
const promise2 = new Promise((resolve, reject) => setTimeout(() => reject(new Error("Whoops!")), 2000));

Promise.allSettled([promise1, promise2])
    .then(results => {
        console.log(results);
        /*
        输出:
        [
            { status: 'fulfilled', value: 1 },
            { status: 'rejected', reason: Error: Whoops! }
        ]
        */
    });

Promise.any

Promise.any(iterable) 方法接收一组 Promise 并返回一个新的 Promise。当其中的第一个 Promise 成功解决时,新的 Promise 就会被解决;如果所有的 Promise 都被拒绝,则返回的 Promise 会以 AggregateError 形式被拒绝。

特性:

  • 返回一个新 Promise。
  • 只需等待第一个 fulfilled 的 Promise。
  • 如果所有 Promise 都被拒绝,则返回的 Promise 会被拒绝,并附带一个包含所有错误信息的 AggregateError 对象。
javascript 复制代码
const promise1 = new Promise((resolve, reject) => setTimeout(() => reject(new Error("Whoops!")), 1000));
const promise2 = new Promise((resolve, reject) => setTimeout(() => resolve(1), 2000));

Promise.any([promise1, promise2])
    .then(result => {
        console.log(result); // 输出: 1
    })
    .catch(errors => {
        console.error(errors.message); // 输出: All Promises were rejected
    });

Promise.race

Promise.race(iterable) 方法接收一组 Promise 并返回一个新的 Promise。当其中的第一个 Promise 解决(不论是成功还是失败)时,新的 Promise 就会被解决。

特性:

  • 返回一个新 Promise。
  • 只需等待第一个 settled 的 Promise。
  • 第一个 settle 的 Promise 决定了返回 Promise 的状态(fulfilled 或 rejected)。
javascript 复制代码
const promise1 = new Promise((resolve, reject) => setTimeout(() => resolve(1), 1000));
const promise2 = new Promise((resolve, reject) => setTimeout(() => reject(new Error("Whoops!")), 2000));

Promise.race([promise1, promise2])
    .then(result => {
        console.log(result); // 输出: 1
    })
    .catch(error => {
        console.error(error);
    });

总结:

  1. Promise.all: 必须所有 Promise 都成功才能解决问题。
  2. Promise.allSettled: 等待所有 Promise 完结,无论成功与否。
  3. Promise.any: 至少一个 Promise 成功即可解决问题。
  4. Promise.race: 最快的那个决定一切。
相关推荐
Carlos_sam2 分钟前
Opnelayers:ol-wind之Field 类属性和方法详解
前端·javascript
小毛驴85013 分钟前
创建 Vue 项目的 4 种主流方式
前端·javascript·vue.js
CodeCraft Studio32 分钟前
借助Aspose.HTML控件,在 Python 中将 HTML 转换为 Markdown
开发语言·python·html·markdown·aspose·html转markdown·asposel.html
QQ_43766431433 分钟前
C++11 右值引用 Lambda 表达式
java·开发语言·c++
aramae34 分钟前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法
誰能久伴不乏41 分钟前
Linux如何执行系统调用及高效执行系统调用:深入浅出的解析
java·服务器·前端
封奚泽优1 小时前
使用Python实现单词记忆软件
开发语言·python·random·qpushbutton·qtwidgets·qtcore·qtgui
涔溪2 小时前
响应式前端设计:CSS 自适应布局与字体大小的最佳实践
前端·css
今禾2 小时前
前端开发中的Mock技术:深入理解vite-plugin-mock
前端·react.js·vite
你这个年龄怎么睡得着的2 小时前
Babel AST 魔法:Vite 插件如何让你的 try...catch 不再“裸奔”?
前端·javascript·vite