摘要:換句話說該靜態(tài)函數(shù)返回個處于狀態(tài)的對象。等價于構(gòu)造函數(shù)的靜態(tài)函數(shù),創(chuàng)建一個對象并以值作為參數(shù)調(diào)用句柄函數(shù)。等價于介紹構(gòu)造函數(shù)的靜態(tài)函數(shù),參數(shù)是對象組成的可迭代數(shù)據(jù)集合。
一、概述
ES2015 Promise函數(shù)是對PromiseA+標準的實現(xiàn),并且嚴格遵守該標準。
二、APIs 2.1 創(chuàng)建Promise對象Promise構(gòu)造函數(shù)的參數(shù)是個包含兩個參數(shù)的函數(shù),并且該函數(shù)的參數(shù)分別對應(yīng)resolve, reject操作(resolve,reject也是函數(shù))。并且只能通過這兩個參數(shù)改變Promise的狀態(tài)。
function asynOperation(){ var promise = new Promise(function(resolve, reject){ setTimeout(function(){ reject(1,2,3); // 調(diào)用reject操作,并傳遞reason參數(shù)。雖然傳遞多個參數(shù),但只把第一個作為reson值,符合Promise A+標準 }, 3000) }); return promise; } asynOperation().then(function(value){ console.log("ES2015 Promise: resolved and value is " + value); }, function(reason){ console.log("ES2015 Promise: rejected and reason is " + reason); })
上面的代碼用zpotojs實現(xiàn):
/* ZeptoJS Deferred */ function AsynOperation1(){ var deferred = $.Deferred(); setTimeout(function(){ deferred.reject(1, 2, 3); }, 3000); return deferred.promise(); } AsynOperation1().then(function(val){ console.log("Fullfilled: " + val); }, function(reason){ console.log("Rejected: " + reason); })2.2 Promise.prototype.catch
catch方法用來添加Rejected狀態(tài)回調(diào),是then方法的一種子集。
asynOperation().catch(function(reason){ }) // 等價于 asynOperation().then(undefined, function(reason){ })2.3 Promise.reject(reason)
Promise構(gòu)造函數(shù)的靜態(tài)方法,創(chuàng)建個Promise對象并以reason值調(diào)用reject句柄函數(shù)。換句話說該靜態(tài)函數(shù)返回個處于“Rejected”狀態(tài)的Promise對象。
var p = Promise.reject(1); // 等價于 var p = new Promise(function(resolve, reject){ reject(1); })2.4 Promise.resolve(value)
Promise構(gòu)造函數(shù)的靜態(tài)函數(shù),創(chuàng)建一個Promise對象并以value值作為參數(shù)調(diào)用resolve句柄函數(shù)。換句話說該靜態(tài)函數(shù)返回個處于“fullfilled"狀態(tài)的Promise對象。
var p = Promise.resolve(1); // 等價于 var = new Promise(function(resolve){ resolve(1); })2.5 Promise.all(iterable) 2.5.1 介紹
Promise構(gòu)造函數(shù)的靜態(tài)函數(shù),參數(shù)是Promise對象組成的可迭代數(shù)據(jù)集合。創(chuàng)建個Promise對象,并且參數(shù)指定的所以Promise都解決后,該Promise對象該被解決,反之如果其中存在rejected的Promise,則該Promise對象被rejected。
定義個異步操作:
function asynOperation(value, reason){ var promise = new Promise(function(resolve, reject){ setTimeout(function(){ value === undefined ? reject(reason) : resolve(value); }, 3000) }); return promise; } var p1 = asynOperation(1), p2 = asynOperation(2), p3 = asynOperation(3); Promise.all([p1, p2, p3]).then(function(value){ console.log("all resolved: value is " + value); // value是[1, 2, 3] })
如果參數(shù)元素中發(fā)生rejected操作,則立馬reject返回的Promise:
var p1 = asynOperation(1), p2 = asynOperation(undefined, 2), // reject操作 p3 = asynOperation(undefined, 3); // reject操作 p2.catch(function(reson){ console.log("p2") }) p3.catch(function(reson){ console.log("p3") }) Promise.all([p1, p2, p3]).then(function(value){ console.log("all resolved: value is " + value) }, function(reason){ console.log("one rejected: reason is " + reason); // reson值等于發(fā)生reject操作的promise對象的reason,即p2 })
顯示結(jié)果:
2.5.2 對比$.whenPromise.all和$.when很類似。主題功能差不多,參數(shù)傳遞方式不一樣:ES2015中把所有的Promise對象的value構(gòu)建個數(shù)組,而$.when是分別傳遞的。
function AsynOperation1(value, reason){ var deferred = $.Deferred(); setTimeout(function(){ value === undefined ? deferred.reject(reason) : deferred.resolve(value); }, 3000); return deferred.promise(); } var p1 = AsynOperation1(1), p2 = AsynOperation1(2), p3 = AsynOperation1(3); $.when(p1, p2, p3).then(function(value){ console.log("resolved " + value); // 留意Value的值 }, function(reason){ console.log("rejected " + reason); })2.6 Promise.race(iterable)
Promise構(gòu)造函數(shù)的靜態(tài)函數(shù),參數(shù)是Promise對象構(gòu)成的可迭代對象,創(chuàng)建個Promise對象。當參數(shù)任意Promise對象fullfilled(rejected)時,則立馬fullfill(reject)該Promise對象。
var p1 = asynOperation(1), p2 = asynOperation(undefined, 2), p3 = asynOperation(undefined, 3); Promise.race([p1, p2, p3]).then(function(value){ console.log("one resolved: value is " + value); // Value=1 }, function(reason){ console.log("one rejected: reason is " + reason) })三、micro-task
Promise的回調(diào)通過micor-task實現(xiàn)的。
console.log(1) setTimeout(function(){ console.log(2)}, 0) Promise.resolve().then(function(){console.log(3)}) console.log(4) // 輸出應(yīng)該是:1 4 3 2四、對比Promise A+ 標準
大部分Promise A+標準的實現(xiàn)對"Promise解決過程"標準的實現(xiàn)略有不同,比如zeptoJs Deferred就沒考慮thenable情況。但是ES2015 Promise函數(shù)完全嚴格遵守Promise A+標準,包含對“Promise 解決過程的實現(xiàn)。下面舉例說明實現(xiàn)Promise解決過程(The Promise Resolution Procedure):[[Resolve]](promise, x)
3.3.1 如果promise對象和x相等,則用TypeError對象作為reason 拒絕promise對象var p1 = asynOperation(1); var p2 = p1.then(function(value){ console.log("resolved: " + value); return p2; // 返回p2對象, },function(reason){ console.log("rejected: " + reason); }}; }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason);
var p1 = asynOperation(1); var p2 = p1.then(function(value){ console.log("resolved: " + value); return asynOperation(2); // 返回個Promise對象,以該Prmoise對象狀態(tài)決定p2的狀態(tài) },function(reason){ console.log("rejected: " + reason); }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason); })3.3.3 如果x是thenable,promise狀態(tài)的改變?nèi)Q于x.then方法的執(zhí)行中resolve,reject句柄的調(diào)用情況。并不受x.then返回值的影響。
A:then方法沒有調(diào)用resolve或者reject,并且沒有返回值,則不會改變promose的狀態(tài)
var p1 = asynOperation(1); var p2 = p1.then(function(value){ console.log("resolved: " + value); return {name: "john", then: function(resolve, reject){ // 返回值是個thenable對象,但是then方法沒有調(diào)用resolve或者reject,并且沒有返回值 }}; },function(reason){ console.log("rejected: " + reason); }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason); })
B:then方法中調(diào)用resolve句柄,用新value y遞歸調(diào)用Promise解決過程:[[Resolve]](promise, y)
var p1 = asynOperation(1); var p2 = p1.then(function(value){ console.log("resolved: " + value); return {name: "john", then: function(resolve, reject){ resolve(2); // then方法中調(diào)用resolve句柄,用新value遞歸調(diào)用Promise解決過程 }}; },function(reason){ console.log("rejected: " + reason); }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason); })
C:then方法中調(diào)用reject句柄,則用相同的reason拒絕promise.
var p1 = asynOperation(1); var p2 = p1.then(function(value){ console.log("resolved: " + value); return {name: "john", then: function(resolve, reject){ reject(2); // 調(diào)用reject句柄 }}; },function(reason){ console.log("rejected: " + reason); }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason); })
D:then方法中多次調(diào)用resolve, reject句柄,只有第一個調(diào)用有效,其他的忽略
E:then方法中拋異常,如果拋異常之前已經(jīng)調(diào)用resolve或者reject句柄,則忽略該異常,反之則以該異常為reason拒絕promise
2.3.4 其他情況,則用x作為value完成promise。var p1 = asynOperation(undefined, 1); // 拒絕的promise var p2 = p1.then(function(value){ console.log("resolved: " + value); return {name: "john"}; },function(reason){ console.log("rejected: " + reason); return 2; }); p2.then(function(value){ console.log("resolved: " + value); },function(reason){ console.log("rejected: " + reason); })還沒結(jié)束
一道關(guān)于Promise應(yīng)用的面試題
參考是時候使用promise了
avaScript Promise迷你書(中文版)
MDN
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/93321.html
摘要:的翻譯文檔由的維護很多人說,阮老師已經(jīng)有一本關(guān)于的書了入門,覺得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開發(fā)過程中,顯得越來越重要。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(中文版) 超詳細介紹promise的gitbook,看完再不會promise...... 本書的目的是以目前還在制定中的ECMASc...
摘要:和和都有和,但是略有不同。實際上返回的是一個對象。和添加的回調(diào),添加的回調(diào)。所以在調(diào)用成功的情況下執(zhí)行添加的回調(diào),調(diào)用失敗時執(zhí)行添加的回調(diào)。,產(chǎn)生對象并,產(chǎn)生對象并,然后繼續(xù)處理,的語法糖,和的差不多但不同。 Deferred 和 Promise ES6 和 jQuery 都有 Deffered 和 Promise,但是略有不同。不過它們的作用可以簡單的用兩句話來描述 Deffere...
摘要:所謂異步編程中的異步是相對于同步的概念的。是一系列異步編程規(guī)范的統(tǒng)稱。如果中的回調(diào)函數(shù)返回一個值,那么返回的將會成為接受狀態(tài),并且將返回的值作為接受狀態(tài)的回調(diào)函數(shù)的參數(shù)值。參考介紹基礎(chǔ)篇深入理解與異步編程。 es6 promise與異步編程 對于一些還不具備大量編程經(jīng)驗的朋友來說,promise可能是es6比較難以掌握的點。首先是很多名詞,比如Promises,es6 Promise,...
摘要:從最開始的到封裝后的都在試圖解決異步編程過程中的問題。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。寫一個符合規(guī)范并可配合使用的寫一個符合規(guī)范并可配合使用的理解的工作原理采用回調(diào)函數(shù)來處理異步編程。 JavaScript怎么使用循環(huán)代替(異步)遞歸 問題描述 在開發(fā)過程中,遇到一個需求:在系統(tǒng)初始化時通過http獲取一個第三方服務(wù)器端的列表,第三方服務(wù)器提供了一個接口,可通過...
摘要:如果有錯誤,則到的第二個回調(diào)函數(shù)中,對錯誤進行處理。假設(shè)第一個的第一個回調(diào)沒有返回一個對象,那么第二個的調(diào)用者還是原來的對象,只不過其的值變成了第一個中第一個回調(diào)函數(shù)的返回值。 ES6標準出爐之前,一個幽靈,回調(diào)的幽靈,游蕩在JavaScript世界。 正所謂: 世界本沒有回調(diào),寫的人多了,也就有了})})})})})。 Promise的興起,是因為異步方法調(diào)用中,往往會出現(xiàn)回調(diào)函數(shù)一...
摘要:就算改變已經(jīng)發(fā)生了,即使再對對象添加回調(diào)函數(shù),也會立即得到這個結(jié)果。方法接收個參數(shù),第一個參數(shù)是狀態(tài)的回調(diào)函數(shù),第二個參數(shù)可選是狀態(tài)的回調(diào)函數(shù)。簡單來講,就是能把原來的回調(diào)寫法分離出來,在異步操作執(zhí)行完后,用鏈式調(diào)用的方式執(zhí)行回調(diào)函數(shù)。 在ECMAScript 6標準中,Promise被正式列為規(guī)范,Promise,字面意思就是許諾,承諾,嘿,聽著是不是很浪漫的說?我們來探究一下這個浪...
閱讀 1724·2021-11-11 10:58
閱讀 4210·2021-09-09 09:33
閱讀 1267·2021-08-18 10:23
閱讀 1555·2019-08-30 15:52
閱讀 1632·2019-08-30 11:06
閱讀 1877·2019-08-29 14:03
閱讀 1513·2019-08-26 14:06
閱讀 2960·2019-08-26 10:39