【ES6】Promise的入门介绍

Promise 是 JavaScript 中的一个对象,用于处理异步操作。Promise 对象代表一个最终可能完成(并得到结果)或失败(并被拒绝)的操作,以及其结果的值。

一个 Promise 有三种状态:

  • Pending(等待):初始状态,既不是成功,也不是失败状态。
  • Fulfilled(实现):意味着操作成功完成。
  • Rejected(拒绝):意味着操作失败。
    Promise 对象只会有这三种状态中的一种。一旦状态改变,就不会再改变。

Promise 对象具有以下方法:

  • then():返回一个 Promise,跟着在 onFulfilled 或 onRejected 里面返回的结果调用 nextPromise 的 done 方法。
  • catch():返回一个 Promise,只执行 onRejected,并在传递给他的 Promise 失败时返回它。通常这个方法是返回 Promise 的最后一个。
    下面是一个简单的 Promise 的使用示例:
javascript 复制代码
let promise = new Promise(function(resolve, reject) {
  // 异步操作
  setTimeout(function() {
    let random = Math.random();
    if (random < 0.5) {
      resolve("成功!"); // 如果随机数小于0.5,则成功
    } else {
      reject("失败!"); // 否则失败
    }
  }, 1000);
});

promise.then(function(value) {
  console.log(value); // 当 Promise 成功时,打印 "成功!"
}).catch(function(reason) {
  console.log(reason); // 当 Promise 失败时,打印 "失败!"
});

在这个例子中,我们创建了一个新的 Promise,它将在 1 秒后根据随机数决定成功或失败。然后我们调用 then() 和 catch() 方法来处理成功或失败的情况。如果 Promise 成功,then() 里的函数会被执行并打印 "成功!"。如果 Promise 失败,catch() 里的函数会被执行并打印 "失败!"。

相关推荐
谎言西西里5 小时前
JS 高手必会:手写 new 与 instanceof
javascript
雪碧聊技术5 小时前
前端项目代码发生改变,如何重新部署到linux服务器?
前端·vue3·centos7·代码更新,重新部署
liulilittle6 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
wordbaby6 小时前
Expo 进阶指南:赋予 TanStack Query “原生感知力” —— 深度解析 AppState 与 NetInfo
前端·react native
Moment6 小时前
从美团全栈化看 AI 冲击:前端转全栈,是自救还是必然 🤔🤔🤔
前端·后端·面试
天问一6 小时前
使用 Vue Router 进行路由定制和调用的示例
前端·javascript·vue.js
韩立学长8 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js
优弧8 小时前
离开舒适区100天,我后悔了吗?
前端·后端·面试
胡gh8 小时前
css的臂膀,前端动效的利器,还是布局的“隐形陷阱”?
前端·css·html
灵感菇_8 小时前
Flutter Riverpod 完整教程:从入门到实战
前端·flutter·ui·状态管理