现在的位置: 首页 > web前端 > 正文

fulfilled的理解使用

2020年07月17日 web前端 ⁄ 共 1219字 ⁄ 字号 评论关闭

  Promise中的resolved和fulfilled到底什么关系,又或者这只是叫法的问题?问题:promise中总会遇到说resolved和fulfilled这两个关键词的,但是有时候总会有那么一丝儿误解或者是朦胧,有时候傻傻分不清,怎么上面说fulfilled状态,下面又变成了resolved状态!?


  fulfilled的理解:


    我知道Promise构造函数接受一个函数作为参数吗,并且该函数可以接受两个参数(也是方法,由js引擎提供)resolve,reject,两个词分别的意思是“解决”和“拒绝,丢弃”。字面上很好理解,其实就是通过这两个方法将Promise的状态由pending转化为fulfilled和rejected的。


      pending->resolve方法->fulfilled


      pending->reject方法->rejected


    由此可以见我的理解就是那些说什么resolved的就是fulfilled状态的,从英语的语法resolved的是resolve的过去式,那就是说“解决了”,那不就是代表了解决了就成功了,所以按照上面流程也正是fulfilled的状态吗,那resolved和fulfilled同一状态咯


    但是从另一个角度又感觉站不住脚,应为解决了就一定是成功了吗???!!!想得有点(‘.’)


  另外引阮神的《ECMAScript6入门》


  promise章节fulfilled的部分段落


    从这个话语中很明显知道,阮神指的resolved也正是我的困扰点,他这里说的明显可以看出来resolved暂指fulfilled状态,要是不是本文呢,要是实际过程中呢,resolved不一定表示状态变为fulfilled状态了,而是会有其他可能,比如说转变为了rejected状态了呢?!


  紧接着问一句,catch,then等回调函数返回的都是resolve的Promise,


    那么请再一次允许我引阮神的promise.all中的原句子:


  上面代码中,promises是包含6个Promise实例的数组,只有这6个实例的状态都变成fulfilled,或者其中有一个变为rejected,才会调用Promise.all方法后面的回调函数。


    所以只有这有状态都变为fulfilled才能执行all后面的回调函数咯!!!


    上图就是描述其实就是:all里面的promise有自己的catch方法时,该promise变为rejected时触发的是自己promise的catch方法,不会触发all方法外面接着的promise的catch方法


    原因很简单:子catch方法回调结束后返回又是一个resolved状态的promise,所以最终接受的子都是resolved的状态的


  总之,fulfilled给大家简单的介绍了一些,希望大家多看看。

抱歉!评论已关闭.