一篇带你了解promise使用过程中会存在什么状态

promise(承诺)的状态

  • Pending(待定):初始状态,表示promise正在执行中,也可能是等待中。
javascript 复制代码
const promise = new Promise((resolve, reject) => {
  // 异步操作
  setTimeout(() => {
    const success = true; // 模拟异步操作成功的条件
    if (success) {
      resolve("操作成功");
    } else {
      reject("操作失败");
    }
  }, 2000); // 假设异步操作需要2秒钟完成
});
console.log(promise);

浏览器执行结果:

  • Fulfilled(已完成):表示promise已成功完成操作,且返回了一个值。
javascript 复制代码
const promise = new Promise((resolve, reject) => {
  // 异步操作
  // 这里可以是一段耗时的异步代码

  resolve("操作成功");
});
promise.then((result) => {
  console.log(result); // 输出:"操作成功"
}).catch((error) => {
  console.error(error);
});

浏览器执行结果:

  • Rejected(已拒绝):表示promise未能成功完成操作,出现了错误或异常情况。 这些状态描述了promise在执行过程中可能经历的不同阶段,帮助开发人员更好地处理异步操作和结果处理。
javascript 复制代码
const promise = new Promise((resolve, reject) => {
  // 异步操作
  // 这里可以是一段耗时的异步代码

  reject("操作失败");
});

promise.then((result) => {
  console.log(result);
}).catch((error) => {
  console.error(error); // 输出:"操作失败"
});

浏览器执行结果:

了解这些状态有什么作用?

  1. Pending(待定)状态 :在 Promise 对象刚被创建时,其状态为 pending。此时可以调用 .then() 方法来注册一个成功回调函数,以及 .catch() 方法来注册一个失败回调函数,用于处理异步操作的成功和失败情况。
  2. Fulfilled(已完成)状态 :当 Promise 对象的异步操作成功完成时,其状态会变为 fulfilled。此时可以调用 .then() 方法来注册一个成功回调函数,用于处理异步操作成功的情况。
  3. Rejected(已失败)状态 :当 Promise 对象的异步操作失败时,其状态会变为 rejected。此时可以调用 .catch() 方法来注册一个失败回调函数,用于处理异步操作失败的情况。

所以熟练掌握并迅速了解当前代码下promise处于什么状态,有助于我们快速解决异步操作不同情况下的问题。

总结:

在使用 Promise 过程中,主要存在三种状态:Pending(待定)、Fulfilled(已完成)和 Rejected(已失败)。当 Promise 对象刚被创建时,处于待定状态;异步操作成功完成时,进入已完成状态;异步操作失败时,进入已失败状态。通过这些状态变化,我们可以清晰地了解异步操作的执行情况,并在合适的时机进行处理。在编写异步代码时,合理处理这些状态变化是保证程序健壮性和可靠性的关键。

总之,Promise 的状态变化体现了异步操作的承诺和执行过程,通过合理处理不同状态,我们可以实现更可靠的异步编程。如果本文对你有所帮助,还望点个赞支持一下,感谢大家。

相关推荐
爱掉发的小李2 分钟前
前端开发中的输出问题
开发语言·前端·javascript
Dolphin_海豚15 分钟前
一文理清 node.js 模块查找策略
javascript·后端·前端工程化
祝余呀34 分钟前
HTML初学者第四天
前端·html
浮桥2 小时前
vue3实现pdf文件预览 - vue-pdf-embed
前端·vue.js·pdf
七夜zippoe2 小时前
前端开发中的难题及解决方案
前端·问题
晓13133 小时前
JavaScript加强篇——第七章 浏览器对象与存储要点
开发语言·javascript·ecmascript
Hockor3 小时前
用 Kimi K2 写前端是一种什么体验?还支持 Claude Code 接入?
前端
杨进军3 小时前
React 实现 useMemo
前端·react.js·前端框架
海底火旺3 小时前
浏览器渲染全过程解析
前端·javascript·浏览器
你听得到113 小时前
揭秘Flutter图片编辑器核心技术:从状态驱动架构到高保真图像处理
android·前端·flutter