Promise学习总结

异步编程

  • 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对象

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值