(1)ES6方式
http://liubin.github.io/promises-book/#promise-is-always-async
即使在調用promise.then
注冊回調函數的時候promise
對象已經是確定的狀態(tài),
<u></u>Promise
也會以異步的方式調用該回調函數,這是在Promise
設計上的規(guī)定方針。
例如:
var pro=new Promise(function(resolve){
resolve(1);
});
//已經resolve了,再設置then回調。
pro.then(function(v){
alert(v); //1
});
alert(2);
//還是會已異步方式,發(fā)生回調。
//先alert(2)再alert(v);
//而且,以后什么時候注冊then,都會異步調用。
(2)jQuery方式
但是jQuery的promise
并不是如此。
例如:
var defer=$.Deferred();
defer.resolve(1);
//deferred對象已經resolve了
defer.done(function(v){
alert(v); //不會執(zhí)行
});
alert(2);
//只執(zhí)行alert(2);
//如果需要執(zhí)行done,就要把注冊done回調放到defer.resolve()之前。
注:
jQuery的promise
是一種限制化的deferred
對象。
var defer=$.Deferred();
var promise=defer.promise();
promise
沒有resolve
,reject
,notify
方法,不能進行狀態(tài)更改,
只能注冊回調。