目录

【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);
  });
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
孤客网络科技工作室9 分钟前
每天学一个 Linux 命令(7):cd
java·linux·前端
JSON_L13 分钟前
Vue 组件通信 - Ref组件通信
javascript·vue.js·ecmascript
努力的搬砖人.14 分钟前
Vue 2 和 Vue 3 有什么区别
前端·vue.js·经验分享·面试
Json_1817901448032 分钟前
python采集淘宝拍立淘按图搜索API接口,json数据示例参考
服务器·前端·数据库
珹洺1 小时前
Java-servlet(十)使用过滤器,请求调度程序和Servlet线程(附带图谱表格更好对比理解)
java·开发语言·前端·hive·hadoop·servlet·html
Fri_1 小时前
Vue 使用 xlsx 插件导出 excel 文件
javascript·vue.js·excel
熙曦Sakura1 小时前
【C++】map
前端·c++
黑贝是条狗1 小时前
html 列表循环滚动,动态初始化字段数据
前端·javascript·html
萌萌哒草头将军2 小时前
🔥🔥🔥4 月 1 日尤雨溪突然宣布使用 Go 语言重写 Rolldown 和 Oxc!
前端·javascript·vue.js
搬砖的阿wei2 小时前
从零开始学 Flask:构建你的第一个 Web 应用
前端·后端·python·flask