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(() => {···});