普通视图

发现新文章,点击刷新页面。
昨天 — 2026年5月8日首页

Promise链式调用原理

作者 卷帘依旧
2026年5月8日 15:39

Promise链式调用原理,then在不同情况下的返回值

在JavaScript中,Promise是一种用于处理异步操作的对象。它可以让你以同步的方式来编写异步代码,从而提高代码的可读性和可维护性。Promise对象代表了异步操作的最终完成(或失败)及其结果值。

Promise的基本用法

一个Promise对象有三种状态:

  1. Pending(等待) ‌ - 初始状态,既不是成功,也不是失败。
  2. Fulfilled(已成功) ‌ - 操作成功完成。
  3. Rejected(已失败) ‌ - 操作失败。

创建Promise

你可以使用new Promise()构造函数来创建一个Promise对象。这个构造函数接受一个执行器函数作为参数,执行器函数有两个参数,分别是resolvereject

let promise = new Promise(function(resolve, reject) {
    // 异步操作
    if (/* 成功条件 */) {
        resolve(value); // 操作成功,将Promise的状态改为Fulfilled,并传递结果值
    } else {
        reject(error); // 操作失败,将Promise的状态改为Rejected,并传递错误信息
    }
});

Promise链式调用

Promise的链式调用是通过.then().catch()方法实现的。.then()方法返回一个新的Promise实例,并且可以接受两个参数:第一个参数是操作成功时的回调函数,第二个参数是操作失败时的回调函数(可选)。.catch()方法用于指定发生错误时的回调函数。

let promise = new Promise((resolve, reject) => {
    setTimeout(() => resolve("成功"), 1000); // 模拟异步操作成功
});

promise.then(result => {
    console.log(result); // "成功"
    return "下一个Promise"; // 这里返回的结果会传递给下一个.then()的回调函数
}).then(result => {
    console.log(result); // "下一个Promise"
}).catch(error => {
    console.log(error); // 错误处理
});

使用async/await进行链式调用

async/await是建立在Promise之上的语法糖,让异步代码的书写和阅读更加直观。async函数可以包含await表达式,await关键字用于等待一个Promise对象解析完成。

async function asyncCall() {
    try {
        let result = await firstPromise(); // 等待第一个Promise解析完成
        let nextResult = await secondPromise(result); // 使用第一个Promise的结果作为第二个Promise的输入,并等待解析完成
        console.log(nextResult); // 处理结果
    } catch (error) {
        console.error(error); // 错误处理
    }
}

总结

通过.then().catch()方法或者使用async/await,你可以很容易地实现Promise的链式调用,使得异步代码的管理变得更加容易和清晰。

❌
❌