Dojo Deferreds 和 Promises

前端之家收集整理的这篇文章主要介绍了Dojo Deferreds 和 Promises前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

Deferred 与 Promise 的关系

Promise的定义: https://promisesaplus.com/ 或者 http://www.alloyteam.com/2014/05/javascript-promise-mode/

  • 简单的说,promise有三种状态
  1. pending状态,pending 状态 可以到 fulfilled 或者 rejected状态 (新创建时)
  2. fulfilled状态,不能改变到其它状态,并且接受一个成功返回的值 (当调用Deferred resolve 或者说 Ajax 请求成功后都会设置状态为 fulfilled)
  3. rejected状态, 不能改变到其它状态,并且接受一个拒绝的原因 (当调用Deferred reject方法,或者调用了 Deferred cancel方法(内部调用reject方法) )
  • promise 必须提供一个then 方法,对于then方法的要求可以查看 https://promisesaplus.com/
Promise 只是一个承诺,根据自己的状态(fulfilled, rejected,通过singalListner触发不同信号),而执行then 方法中定义的回调函数。 但是这个状态的修改,需要 Deferred去调用resolve 或 reject.
Deferred 从字面上认识,一个迟延操作,它有执行的过程(PROGRESS), 执行成功(RESOLVED),或者 (REJECTED). 执行成功和执行失败,都会修改Promise的状态。

让我们还是能过代码, 了解两者之间的关系

第一种情况: 直接定义一个Promise对像
 var  promise = new Promise();
      promise.then()  // 抛出一个错误


所以不能直接初始化一个Promise对像, 因为dojo/promise/Promise只是一个抽像类,而没有具体的方法调用then方法,throw new TypeError("abstract"); 而且Promise规范中没有要求定义修改状态的方法
比如,resolve 和 reject

第二种情况: 定义一个Deferred 对像
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;

原理以及源代码的可以查看 github.

Promise 的使用

翻译官方教程http://dojotoolkit.org/documentation/tutorials/1.10/promises/
原文链接:https://www.f2er.com/dojo/291108.html

猜你在找的Dojo相关文章