Promise三个状态

一个 Promise 对象代表一个异步操作的结果。它可能处于以下三种状态之一:

  1. Pending(待定)

    • 初始状态,既不是成功也不是失败。
    • 在这个状态下,操作尚未完成,也未解决或拒绝。
  2. Fulfilled(已实现)

    • 表示操作成功地完成。
    • 进入这个状态的 Promise 会携带一个值,这个值作为成功的结果。
    • 通过 .then() 方法处理结果。
  3. Rejected(已拒绝)

    • 表示操作失败。
    • 进入这个状态的 Promise 会携带一个原因,表示失败的原因。
    • 通过 .catch() 方法处理错误。

状态转换规则:

  • 一个 Promise 一旦从 Pending 状态变为 Fulfilled 或 Rejected,就不可以再进行其他状态转变。这意味着 Promise 的状态只能改变一次。
  • Promise 只能从 Pending 状态转换成 Fulfilled 或 Rejected 状态。

状态转换流程:

  • PendingFulfilled当异步操作成功完成,并且未来可以用 .then() 方法访问结果。
  • PendingRejected当异步操作失败,未来可以用 .catch() 方法访问错误信息。

示例:

javascript 复制代码
const promiseExample = new Promise((resolve, reject) => {
  // 异步操作
  setTimeout(() => {
    const success = true; // 模拟异步操作结果

    if (success) {
      resolve('操作成功');  // 将 Promise 状态置为 Fulfilled
    } else {
      reject('操作失败');  // 将 Promise 状态置为 Rejected
      console.log('aaaaa', myPromise); //可以直接打印Promise来查看PromiseState, 为rejected.
    }
  }, 1000);
});

promiseExample
  .then(result => console.log(result))   // 输出 "操作成功"
  .catch(error => console.error(error)); // 如果失败,捕获并输出错误

在这个示例中,Promise 在 1 秒后会进入 Fulfilled 状态并输出 '操作成功',或进入 Rejected 状态并输出 '操作失败'

相关推荐
anyup_前端梦工厂2 小时前
了解几个 HTML 标签属性,实现优化页面加载性能
前端·html
前端御书房2 小时前
前端PDF转图片技术调研实战指南:从踩坑到高可用方案的深度解析
前端·javascript
2301_789169542 小时前
angular中使用animation.css实现翻转展示卡片正反两面效果
前端·css·angular.js
风口上的猪20153 小时前
thingboard告警信息格式美化
java·服务器·前端
程序员黄同学3 小时前
请谈谈 Vue 中的响应式原理,如何实现?
前端·javascript·vue.js
爱编程的小庄4 小时前
web网络安全:SQL 注入攻击
前端·sql·web安全
宁波阿成4 小时前
vue3里组件的v-model:value与v-model的区别
前端·javascript·vue.js
柯腾啊5 小时前
VSCode 中使用 Snippets 设置常用代码块
开发语言·前端·javascript·ide·vscode·编辑器·代码片段
weixin_535854225 小时前
oppo,汤臣倍健,康冠科技,高途教育25届春招内推
c语言·前端·嵌入式硬件·硬件工程·求职招聘
扣丁梦想家5 小时前
设计模式教程:装饰器模式(Decorator Pattern)
java·前端·装饰器模式