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

相关推荐
wu8587734571 分钟前
向量数据库不是银弹:从枚举漏检到 ReACT 多轮召回的实践路径
前端·数据库·react.js
meilindehuzi_a2 分钟前
深入理解 JavaScript 执行机制:从编译阶段到调用栈底层实现
开发语言·javascript·ecmascript
古怪今人4 分钟前
[前端]HTML盒模型与尺寸,标准文档流,块级元素、内联元素和行内块,CSS选择器
前端·css
小雨下雨的雨26 分钟前
基于鸿蒙PC Electron框架技术完成的表单验证技术详解
前端·javascript·华为·electron·前端框架·鸿蒙
提子拌饭13327 分钟前
饮料含糖量查询应用 - 鸿蒙PC用Electron框架完整实现
前端·javascript·华为·electron·前端框架·鸿蒙
JustHappy28 分钟前
古法编程秘籍(五):什么是进程和线程?从软件到 CPU 的一次完整旅程
前端·后端·代码规范
爱编程的小金35 分钟前
前端请求库的下一个进化方向:从 Promise 到策略化
前端·alova·前端请求库·请求策略
hsg7736 分钟前
简述:Jensen Huang‘s Footsteps网站全内容分析
前端·javascript·数据库
珑墨1 小时前
前端 AI 开发通用skill
前端
kyriewen1 小时前
一个人+Cursor,7天上线付费小程序:第1天我就想放弃了
前端·微信小程序·cursor