ES6 Promise对象

1、概念
  • 语法上:是一个构造函数,用来生成 Promise 实例;
  • 功能上:用来封装一个异步操作,并可以获取起成功或失败的结果值。
2、三种状态:
  • pending 进行中
  • fulfilled 成功的
  • rejected 失败的
3、特点:
  • 对象的状态不受外界影响,只有异步操作的结果,可以决定当前是哪一种状态。
  • 状态改变只有两种可能(pending -> fulfilled 或者 pending -> rejected ),而且一旦状态改变,就不会再变,任何时候都可以得到这个结果。
TypeScript 复制代码
const P = new Promise((resolve,reject) => {
    resolve('ok')
    reject('error')
}
// 输出结果始终为 ok
4、实例方法
4.1 then 方法
  • 实例状态发生改变时的回调函数;
  • 第一个参数用来处理成功的函数;
  • 第二个参数用来处理失败的函数(一般使用 catch 代替)。
TypeScript 复制代码
getJSON("/posts.json").then(function(json) {
  return json.post;
}).then(function(post) {
  // ...
});
4.2 catch 方法
  • 用来处理发生错误时的回调函数
  • then 的第二个参数的别名
TypeScript 复制代码
getJSON('/posts.json').then(function(posts) {
  // ...
}).catch(function(error) {
  // 处理 getJSON 和 前一个回调函数运行时发生的错误
  console.log('发生错误!', error);
});
4.3 finally 方法
  • 不常用,无参数

  • 不管 Promise 对象最后的状态如何,都会进行的操作

  • 本质是 then 方法的特例

TypeScript 复制代码
promise
.then(result => {···})
.catch(error => {···})
.finally(() => {···});
相关推荐
码间舞5 分钟前
Zustand 与 useSyncExternalStore:现代 React 状态管理的极简之道
前端·react.js
Dream耀6 分钟前
提升React移动端开发效率:Vant组件库
前端·javascript·前端框架
冰菓Neko7 分钟前
HTML 常用标签速查表
前端·html
gis收藏家31 分钟前
从稀疏数据(CSV)创建非常大的 GeoTIFF(和 WMS)
前端
程序视点1 小时前
望言OCR 2025终极评测:免费版VS专业版全方位对比(含免费下载)
前端·后端·github
NUC_Dodamce1 小时前
Cocos3x 解决同时勾选 适配屏幕宽度和 适配屏幕高度导致Widget组件失效的问题
开发语言·javascript·ecmascript
五点六六六1 小时前
前端常见的性能指标采集
前端·性能优化·架构
吳所畏惧1 小时前
NVM踩坑实录:配置了npm的阿里云cdn之后,下载nodejs老版本(如:12.18.4)时,报404异常,下载失败的问题解决
前端·windows·阿里云·npm·node.js·batch命令
陈随易2 小时前
AI新技术VideoTutor,幼儿园操作难度,一句话生成讲解视频
前端·后端·程序员
Pedantic2 小时前
SwiftUI 按钮Button:完整教程
前端