Deferred 与 Promise 的关系
Promise的定义: https://promisesaplus.com/ 或者 http://www.alloyteam.com/2014/05/javascript-promise-mode/
@H_404_3@
@H_404_3@
@H_404_3@
- 简单的说,promise有三种状态
- pending状态,pending 状态 可以到 fulfilled 或者 rejected状态 (新创建时)
- fulfilled状态,不能改变到其它状态,并且接受一个成功返回的值 (当调用Deferred resolve 或者说 Ajax 请求成功后都会设置状态为 fulfilled)
- rejected状态, 不能改变到其它状态,并且接受一个拒绝的原因 (当调用Deferred reject方法,或者调用了 Deferred cancel方法(内部调用reject方法) )
Promise 只是一个承诺,根据自己的状态(fulfilled, rejected,通过singalListner触发不同信号),而执行then 方法中定义的回调函数。 但是这个状态的修改,需要 Deferred去调用resolve 或 reject.
@H_404_3@
Deferred 从字面上认识,一个迟延操作,它有执行的过程(PROGRESS), 执行成功(RESOLVED),或者 (REJECTED). 执行成功和执行失败,都会修改Promise的状态。
@H_404_3@ @H_404_3@ @H_404_3@
@H_404_3@
@H_404_3@ @H_404_3@ @H_404_3@
@H_404_3@
让我们还是能过代码, 了解两者之间的关系
@H_404_3@
@H_404_3@
@H_404_3@
第一种情况: 直接定义一个Promise对像
所以不能直接初始化一个Promise对像, 因为dojo/promise/Promise只是一个抽像类,而没有具体的方法,调用then方法,throw new TypeError("abstract"); 而且Promise规范中没有要求定义修改状态的方法
比如,resolve 和 reject @H_404_3@
@H_404_3@
var promise = new Promise(); promise.then() // 抛出一个错误
所以不能直接初始化一个Promise对像, 因为dojo/promise/Promise只是一个抽像类,而没有具体的方法,调用then方法,throw new TypeError("abstract"); 而且Promise规范中没有要求定义修改状态的方法
比如,resolve 和 reject @H_404_3@
@H_404_3@
第二种情况: 定义一个Deferred 对像
@H_404_3@
第三种情况,包装到第三方对像,并返回一个Promise,dojo/request
var deferred = new Deferred(); // deferred 对像也拥有 then 方法,用于添加回调函数, 跟deferred.promise.then 的操作是一样的 // 但如果只返回 这个deferred.promise的话,就没办法调用resolve reject等方法 var promise = deferred.then(function(a){}(console.log(a),function(err){console.log(err)); // 跟deferred.promise.then是一样的。
第三种情况,包装到第三方对像,并返回一个Promise,dojo/request
var req = request("/"); // 在ajax中, 要初始化一个deferred对像(私有接口, 不会返回这个对像,request 对像会内部操作 deferred.resolve,及 deferred.reject),并返回这个deferred 的promise;@H_404_3@