异步编程
-
fs 文件操作
require(‘fs’).readFile(‘./index.html’,(err, data) => {});
-
数据库操作
-
AJAX
$.get(‘/server’,(data) => {})
-
定时器
setTimeout(() =>{},1000)
Promise的优点
-
支持链式调用,可以解决回调地狱问题
1:什么是回调地狱?
回调函数嵌套调用,外部回调函数异步执行的结果是嵌套的回调执行的条件
2:回调地狱的缺点?
不便于阅读,不便于异常处理
3:解决方案?
promise链式调用
-
指定回调函数的方式更加灵活
1:旧的:必须在启动异步任务前指定
2:promise:启动异步任务=》返回promise对象=》给promise对象绑定回调函数(甚至可以在异步任务结束后指定/多个)
如何使用Promise
-
api
1:Promise构造函数 Promise(excutor)
excutor函数:执行器 (resolve,reject)=>{}
resolve函数:内部定义成功时调用的函数 value=>{}
reject函数:内部定义失败时调用的函数 reason=>{}
说明:excutor会在Promise内部立即同步调用,异步操作在执行器中执行
2:Promise.prototype.then方法(onResolved,onRejected)=>{}
(1) onResolved函数:成功的回调函数(value=>{})
(2) onRejected函数:失败的回调函数(reason=>{})
说明:指定用于得到成功的value的成功回调和用于得到失败reason的失败回调返回一个新的Promise对象
3:Promise.prototype.catch方法(onRejected)=>{}
(1) onRejected函数:失败的回调函数(reason=>{})
4:Promise.resolve方法 (value=>{})
value:成功的数据或一个promise对象
说明:传入是一个基本类型值时,返回成功的promise
传入的是一个promise对象时,返回的结果取决于传入的promise的结果
返回一个成功/失败的promise对象
5:Promise.reject (reason=>{})
reason:失败的原因
说明:无论传入什么,返回的都是一个失败的promise对象。传入的是什么值返回对象的结果就是什么值
6:Promise.all (promises)=>{}
promises:包含n个promise的数组
说明:返回一个新的Promise,只有所有的promise都成功才算成功,只要有一个失败了就直接失败
7:Promise.race (promises)=>{}
promises:包含n个promise的数组
说明:返回一个新的Promise,第一个完成的Promise的结果状态就是最终返回的Promise的结果状态
Promise的状态改变
promise的状态是promise实例对象中的一个属性 [PromiseState],有三种状态值分别为:pending(未决定的)、resolved(fulfilled)成功、reject失败
-
1:pending变为resolved
-
2:pending变为rejected
说明:只有这两种,且一个promise对象只能改变一次
无论变成失败或者成功,都会有一个结果数据
成功的结果数据一般成为value,失败的结果数据一般为reason
Promise对象的值
是实例对象中的另一个属性[PromiseResult],保存着对象成功/失败的结果
- resolve
- reject
只有这两个函数可以修改PromiseResult的值
Promise的几个关键问题
-
如何改变promise的状态
resolve(value):如果当前是pending就会变成resolved(fulfilled)
reject(value):如果当前是pending就会变成rejected
抛出异常:如果当前是pending就会变成rejected
-
一个promise指定多个成功/失败回调函数,都会调用吗?
当promise改变为对应状态时都会调用
-
改变promise状态和指定回调函数谁先谁后(指定回调代表执行then方法而不是回调方法)
(1)都有可能,正常情况下是先指定回调在改变状态,但也可以先改变状态再指定回调
(2)如何先该状态再指定回调?
在执行器中直接调用resolve()/reject()
延迟更长时间调用then
(3)什么时候才能得到数据?
如果先指定的回调,那当状态发生改变时,回调函数就会调用,得到数据
如果先改变状态,那当指定回调时,回调函数就会调用,得到数据
-
promise.then返回的新promise的结果状态由什么决定?
(1)简单表达:由then()指定的回调函数执行的结果决定
(2)详细表达:
如果抛出异常,新promise变为rejected,reason为抛出的异常
如果返回的是promise的任意值,新promise变为resolved,value为返回的值
如果返回的是另一个新的promise,此promise的结果就会成为新的promise的结果
-
promise如何串联多个操作任务
(1)promise的then()返回一个新的promise,可以开成then()的链式调用
(2)通过then的链式调用串联多个同步/异步任务
-
promise的异常穿透
当使用promise的then链式调用时,可以在最后指定失败的回调
前面任何操作出了异常,都会传到最后失败的回调中处理
-
如何中断promise链?
当使用promise的then链式调用时,不再调用后面的回调函数
办法:在回调函数中返回一个pending状态的promise对象