Promise简述
Promise
Promise是JS中进行异步编程的新的解决方案
- promise: 是一个构造函数
- Promise的构造函数接收一个参数,是函数,并且传入两个参数:resolve,reject,分别表示异步操作执行成功后的回调函数和异步操作执行失败后的回调函数。
- new 出来的 Promise 实例对象,代表一个异步操作
- 每一次 new Promise() 构造函数得到的实例对象,都可以通过原型链的方法访问到.then方法
- .then() 方法用来预先指定成功和失败的回调函数
- 调用 .then() 方法时,成功的回调函数是必选的,失败的回调函数是可选的
- catch() 方法用来捕获与处理错误
Promise 的状态改变
pending –> resolved
pending –> rejected
说明: 只有这 2 种, 且一个 promise 对象只能改变一次
无论变为成功还是失败, 都会有一个结果数据
成功的结果数据一般称为 vlaue, 失败的结果数据一般称为 reason
流程图
为什么要用Promise
- 指定回调函数的方法更加灵活
- 支持链式调用 ,可以解决回调函数问题
基础
1 | 1. Promise 构造函数: Promise (excutor) {} |
Promise关键问题
- 如何改变 promise 的状态?
(1) resolve(value): 如果当前是 pendding 就会变为 resolved
(2) reject(reason): 如果当前是 pendding 就会变为 rejected
(3) 抛出异常: 如果当前是 pendding 就会变为 rejected
- 一个 promise 指定多个成功/失败回调函数, 都会调用吗?
当 promise 改变为对应状态时都会调用
- 改变 promise 状态和指定回调函数谁先谁后?
(1) 都有可能, 正常情况下是先指定回调再改变状态, 但也可以先改状态再指定回调
(2) 如何先改状态再指定回调?
1 在执行器中直接调用 resolve()/reject()
2 延迟更长时间才调用 then()
(3) 什么时候才能得到数据?
1 如果先指定的回调, 那当状态发生改变时, 回调函数就会调用, 得到数据
2 如果先改变的状态, 那当指定回调时, 回调函数就会调用, 得到数据
- promise.then()返回的新 promise 的结果状态由什么决定?
(1) 简单表达: 由 then()指定的回调函数执行的结果决定
(2) 详细表达:
1 如果抛出异常, 新 promise 变为 rejected, reason 为抛出的异常
2 如果返回的是非 promise 的任意值, 新 promise 变为 resolved, value 为返回的值
3 如果返回的是另一个新 promise, 此 promise 的结果就会成为新 promise 的结果
- promise 如何串连多个操作任务?
(1) promise 的 then()返回一个新的 promise, 可以开成 then()的链式调用
(2) 通过 then 的链式调用串连多个同步/异步任务
- promise 异常传透?
(1) 当使用 promise 的 then 链式调用时, 可以在最后指定失败的回调,
(2) 前面任何操作出了异常, 都会传到最后失败的回调中处理
- 中断 promise 链?
(1) 当使用 promise 的 then 链式调用时, 在中间中断, 不再调用后面的回调函数
(2) 办法: 在回调函数中返回一个 pendding 状态的 promise 对象