【JavaScript】Promise详解

Promise 是 JavaScript 中处理异步操作的一种强大机制。它提供了一种更清晰、更可控的方式来处理异步代码,避免了回调地狱(callback hell)和复杂的错误处理。

基本概念

  1. 状态

    • Pending:初始状态,既不是成功也不是失败。
    • Fulfilled:操作成功完成。
    • Rejected:操作失败。
  2. 方法

    • then:处理 fulfilled 状态。
    • catch:处理 rejected 状态。
    • finally:无论成功还是失败都会执行。

创建 Promise

你可以使用 new Promise 构造函数来创建一个 Promise 对象:

javascript 复制代码
const myPromise = new Promise((resolve, reject) => {
  // 异步操作
  setTimeout(() => {
    const success = Math.random() > 0.5;
    if (success) {
      resolve('Operation succeeded');
    } else {
      reject(new Error('Operation failed'));
    }
  }, 1000);
});

处理 Promise

你可以使用 .then.catch 方法来处理 Promise 的结果:

javascript 复制代码
myPromise
  .then(result => {
    console.log('Success:', result);
  })
  .catch(error => {
    console.error('Error:', error.message);
  });

链式调用

Promise 支持链式调用,可以依次处理多个异步操作:

javascript 复制代码
myPromise
  .then(result => {
    console.log('First success:', result);
    return 'Second operation';
  })
  .then(secondResult => {
    console.log('Second success:', secondResult);
  })
  .catch(error => {
    console.error('Error:', error.message);
  });

使用 async/await

async/await 是处理 Promise 的语法糖,使异步代码看起来像同步代码:

javascript 复制代码
async function handleMyPromise() {
  try {
    const result = await myPromise;
    console.log('Success:', result);
  } catch (error) {
    console.error('Error:', error.message);
  }
}

handleMyPromise();

常见的 Promise 方法

  • Promise.all:等待所有 Promise 完成。
  • Promise.race:等待第一个 Promise 完成。
  • Promise.resolve:立即解析的 Promise。
  • Promise.reject:立即拒绝的 Promise。

示例

javascript 复制代码
// 使用 Promise.all
const promise1 = Promise.resolve('First');
const promise2 = new Promise(resolve => setTimeout(() => resolve('Second'), 1000));
const promise3 = Promise.reject(new Error('Third'));

Promise.all([promise1, promise2, promise3])
  .then(values => {
    console.log('All promises resolved:', values);
  })
  .catch(error => {
    console.error('One of the promises was rejected:', error.message);
  });

// 使用 Promise.race
Promise.race([promise1, promise2, promise3])
  .then(value => {
    console.log('First resolved promise:', value);
  })
  .catch(error => {
    console.error('First rejected promise:', error.message);
  });
相关推荐
布列瑟农的星空7 小时前
Playwright使用体验
前端·单元测试
卤代烃7 小时前
🦾 可为与不可为:CDP 视角下的 Browser 控制边界
前端·人工智能·浏览器
_XU8 小时前
AI工具如何重塑我的开发日常
前端·人工智能·深度学习
C_心欲无痕8 小时前
vue3 - defineExpose暴露给父组件属性和方法
前端·javascript·vue.js·vue3
鹿人戛8 小时前
HarmonyOS应用开发:相机预览花屏问题解决案例
android·前端·harmonyos
萌萌哒草头将军8 小时前
绿联云 NAS 安装 AudioDock 详细教程
前端·docker·容器
贺今宵9 小时前
安装better-sqlite3报错electron-vite
javascript·sql·sqlite·sqlite3
GIS之路9 小时前
GIS 数据转换:使用 GDAL 将 GeoJSON 转换为 Shp 数据
前端
2501_944446009 小时前
Flutter&OpenHarmony文件夹管理功能实现
android·javascript·flutter
朴shu9 小时前
Luckysheet 远程搜索下拉 控件开发 : 揭秘二开全流程
前端