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给大家简单的介绍了一些,希望大家多看看。