Promise.race() 方法
關於Promise物件的基本介紹可以參閱JavaScript Promise 物件一章節。
Promise的靜態方法,將多個Promise物件包裝成一個新的Promise物件。
race翻譯成漢語具有"競賽"或者"賽跑"的意思,恰如其名,哪個Promise物件狀態改變的快。
方法返回的Promise物件的狀態就隨著對應的Promise物件狀態發生改變。
語法結構:
[JavaScript] 純文字檢視 複製程式碼p=Promise.race(iterable);
語法解析:
(1).iterable:必需,具有遍歷器介面的物件。
iterable中的元素是Promise物件,如果不是,需要用Promise.resolve()將其轉換為一個Promise物件。
只要iterable中的任意一個Promise物件狀態改變,那麼p物件狀態也會跟著改變。
程式碼例項如下:
[JavaScript] 純文字檢視 複製程式碼執行程式碼let p1 = new Promise(function(resolve, reject) { setTimeout(resolve, 500, "螞蟻部落一"); }); var p2 = new Promise(function(resolve, reject) { setTimeout(resolve, 100, "螞蟻部落二"); }); Promise.race([p1, p2]).then(function(value) { console.log(value); });
程式碼執行效果截圖如下:
程式碼分析如下:
(1).Promise.race() 方法引數是一個陣列,陣列元素是Promise物件。
(2).很明顯是p2的狀態首先發生變化,於是將"螞蟻部落二"傳遞給then的回撥函式。
(3).所以列印結果是"螞蟻部落二"。
[JavaScript] 純文字檢視 複製程式碼執行程式碼let p1 = new Promise(function(resolve, reject) { setTimeout(reject, 50, "螞蟻部落一"); }); var p2 = new Promise(function(resolve, reject) { setTimeout(resolve, 100, "螞蟻部落二"); }); Promise.race([p1, p2]).then(function(value) { console.log(value); },function(value){ console.log(value); });
程式碼執行效果截圖如下:
程式碼分析如下:
(1).Promise.race() 方法引數是一個陣列,陣列元素是Promise物件。
(2).很明顯是p1的狀態首先發生改變,變為rejected。
(3).於是會執行then的第二個回撥函式,並將"螞蟻部落一"作為引數傳遞給回撥函式。
(4).所以最終列印結果是"螞蟻部落一"。
相關文章
- 如何使用Promise.race() 和 Promise.any() ?Promise
- 通過koa2和Promise.race()構造一個超時取消的ajax。Promise
- Java中parse方法,ValueOf方法,toString方法Java
- Python例項方法、類方法、靜態方法Python
- js includes方法 和 filter方法JSFilter
- Java的方法靜態方法Java
- show()方法和hide()方法IDE
- 方法
- 徹底理解了call()方法,apply()方法和bind()方法APP
- Python Class 的例項方法/類方法/靜態方法Python
- slideUp()方法和slideDown()方法IDE
- Java方法03:方法的過載Java
- 物件導向2--靜態方法、類方法、屬性方法物件
- javaSE-day04--ArrayList基本用方法、類內定義方法和方法過載、靜態方法static(類的方法)、工具方法(static)的定義和使用Java
- 來看看兩種好玩的方法,擴充套件方法和分部方法套件
- initialize方法與load方法比較
- Java System類,currentTimeMillis方法,arraycopy方法。Java
- jQuery方法原始碼定位簡單方法jQuery原始碼
- 細說equals()方法和hashCode()方法
- prop()方法和attr()方法的區別
- 詳解equals()方法和hashCode()方法
- exitFullscreen() 方法
- Promise then() 方法Promise
- removeProperty() 方法REM
- deleteRule() 方法delete
- getPropertyPriority() 方法
- getPropertyValue() 方法
- javascriptreplaceAll方法JavaScript
- main方法AI
- 字串方法字串
- 方法引用
- Java方法Java
- call() 方法
- 類方法
- Main()方法AI
- 【MyBatis原始碼分析】insert方法、update方法、delete方法處理流程(上篇)MyBatis原始碼delete
- 【MyBatis原始碼分析】insert方法、update方法、delete方法處理流程(下篇)MyBatis原始碼delete
- 方法的過載、可變形參的方法、方法的引數值傳遞機制、遞迴方法遞迴