加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Dojo Deferreds 和 Promises

发布时间:2020-12-16 21:25:33 所属栏目:百科 来源:网络整理
导读:Deferred 与 Promise 的关系 Promise的定义: https://promisesaplus.com/ 或者 http://www.alloyteam.com/2014/05/javascript-promise-mode/ 简单的说,promise有三种状态 pending状态,pending 状态 可以到 fulfilled 或者 rejected状态 (新创建时) fulfill

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/

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读