摘要:前言的正式版后,我們看到新增加了一個對象它是用來處理異步操作的,以前的異步操作書寫并不是很美觀,而且在回調函數中和并不會帶到我們想要的狀態。另外我們還可以在的回調函數中去使用調用另一對象。
前言
ECMAScript 6 的正式版后,我們看到新增加了一個對象Promise,它是用來處理異步操作的,以前的異步操作書寫并不是很美觀,而且在回調函數中 return和 throw 并不會帶到我們想要的狀態。而Promise 很好的解決了這些問題。
了解 promisepromise 對象存在三種狀態,進行中、結束、失敗。當從進行中到結束狀態或從進行中到失敗狀態時,會觸發reslove、reject函數。
Promise 對象用法// 創建 promise let promise = new Promise(function(reslove,reject){ if(/ * 成功 */){ reslove(values) // 成功調用reslove函數 }else{ reject(values) // 失敗調用 reject函數 } }) // 調用 promise.then(function(val){ // 調用reslove() 函數 },function(val){ 調用 reject() 函數 })
reslove 和 reject 函數并不我們自己聲明的,而是js底層為我們封裝好的。當我們在 promise對象中成功時調用reslove函數,它會觸發then方法中的第一個函數,當我們在 promise對象中成功時調用reject函數,它會觸發then方法中的第二個函數,另外then中的第二個方法我們可以省略。我們可以使用 catch 來接受一些錯誤信息。
promise.then((val) =>{ // 成功處理 }).catch((val) =>{ // 錯誤處理 })
在創建的promise構造函數里或then的回調函數里遇到的錯誤信息都會被catch捕獲到,我們來看一個例子
let promise = function(time){ return new Promise(function(relove, reject){ if(typeof time == "number"){ setTimeout(relove,time,"調用成功"); }else{ reject("調用失敗") } }) } promise(100).then((val) =>{ console.log(val) // 調用成功 }) promise("fda").then((val) =>{ console.log(val) // 調用失敗 }) promise(100).then((val) =>{ new throw("出錯了") console.log(val) // 不執行 }).catch((val) => { console.log(val) //出錯了 })
現在我們應該對promise有一定的了解,使用promise還有一定的好處是,我們可以在then回調函數中去使用 return 語句和 throw 語句,上面我們已經使用了throw 語句。另外我們還可以在then的回調函數中去使用調用另一 promise 對象。這樣比我們使用AJAX交互時嵌套訪問清晰的多。
promiseOne.then(()=>{ promiseTwo.then(() =>{ }) }).catch(() =>{ })
另外,我們應該知道,then 方法和 catch 方法是綁定到了 promise對象的原型上邊了。
Promise 對象的其他用法1. Promise.all()
該方法用于將多個 Promise 實例,包裝成一個新的 Promise 實例。
let promise = Promise.all([promiseOne,promiseTwo]);
這種情況下當 promiseOne 和 promiseTwo 都成功調用 promise 才會被成功調用,
2. Promise.race()
該方法同樣是將多個Promise實例,包裝成一個新的Promise實例。只不過在這種情況下,只要其中一個被成功調用,promise 就會被成功調用。
Promise.resolve()
將對象轉換為 Promise,這里有四中情況
(1)參數是一個Promise實例
let promise = new Promise(function(relove,reject){ }) // 返回promise let promiseNew = Promise.resolve(promise)
如果參數是Promise實例,那么Promise.resolve將不做任何修改、原封不動地返回這個實例。
(2)參數是一個thenable對象
thenable對象就是帶有 then 方法的對象
let obj ={ then(relove,reject){ relove(111) } } let promiseNew = Promise.resolve(obj) promiseNew.then((val) =>{ console.log(val) // 111 })
這時Promise.resolve(obj) 會將obj轉化為Promise對象,并立即執行then方法
(3)參數不是具有then方法的對象,或根本就不是對象
let promiseNew = Promise.resolve(1234) promiseNew.then((val) =>{ console.log(val) // 1234 })
(4)不帶有任何參數
// 返回一個 relove狀態的Promise對象 let promiseNew = Promise.resolve()
需要注意的是,立即resolve的Promise對象,實在事件循環結束時,而不是開始時,如:
setTimeout(function(){ console.log(111) }) Promise.resolve().then(() =>{ console.log(222) }) console.log(333) // 333 // 222 // 111
setTimeout 是在下一個事件循環時執行,Promise.reslove 是在事件循環結束是調用, console 是立即調用
Promise.reject()
Promise.reject(reason)方法也會返回一個新的 Promise 實例,該實例的狀態為rejected。
var p = Promise.reject("出錯了"); // 等同于 var p = new Promise((resolve, reject) => reject("出錯了")) p.then(null, function (s) { console.log(s) }); // 出錯了
注意,Promise.reject()方法的參數,會原封不動地作為reject的理由,變成后續方法的參數。這一點與Promise.resolve方法不一致。
done()
該方法是Promise 對象的回調鏈,不管以then方法或catch方法結尾,要是最后一個方法拋出錯誤,都有可能無法捕捉到(因為Promise內部的錯誤不會冒泡到全局)。因此,我們可以提供一個done方法,總是處于回調鏈的尾端,保證拋出任何可能出現的錯誤。
promise.then() .catch() .then() .catch() .done() // 接收錯誤,并向全局拋出
finally()
finally方法用于指定不管Promise對象最后狀態如何,都會執行的操作。它與done方法的最大區別,它接受一個普通的回調函數作為參數,該函數不管怎樣都必須執行。
promise.then() .finally() // 不管then() 是否有錯,finally都會執行結束
promise 對象的使用并不是很難,這里我參考了阮一峰老師的書籍。
參考書籍:《ECMAScript 6 入門》
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/89348.html
摘要:的翻譯文檔由的維護很多人說,阮老師已經有一本關于的書了入門,覺得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開發過程中,顯得越來越重要。為了讓編程更美好,我們就需要引入來降低異步編程的復雜性。 JavaScript Promise 迷你書(中文版) 超詳細介紹promise的gitbook,看完再不會promise...... 本書的目的是以目前還在制定中的ECMASc...
摘要:和和都有和,但是略有不同。實際上返回的是一個對象。和添加的回調,添加的回調。所以在調用成功的情況下執行添加的回調,調用失敗時執行添加的回調。,產生對象并,產生對象并,然后繼續處理,的語法糖,和的差不多但不同。 Deferred 和 Promise ES6 和 jQuery 都有 Deffered 和 Promise,但是略有不同。不過它們的作用可以簡單的用兩句話來描述 Deffere...
摘要:如果有錯誤,則到的第二個回調函數中,對錯誤進行處理。假設第一個的第一個回調沒有返回一個對象,那么第二個的調用者還是原來的對象,只不過其的值變成了第一個中第一個回調函數的返回值。 ES6標準出爐之前,一個幽靈,回調的幽靈,游蕩在JavaScript世界。 正所謂: 世界本沒有回調,寫的人多了,也就有了})})})})})。 Promise的興起,是因為異步方法調用中,往往會出現回調函數一...
摘要:回調函數這是異步編程最基本的方法。對象對象是工作組提出的一種規范,目的是為異步編程提供統一接口。誕生后,出現了函數,它將異步編程帶入了一個全新的階段。 更多詳情點擊http://blog.zhangbing.club/Ja... Javascript 語言的執行環境是單線程的,如果沒有異步編程,根本沒法用,非卡死不可。 為了解決這個問題,Javascript語言將任務的執行模式分成兩種...
摘要:關于的入門了解新增模板字符串為提供了簡單的字符串插值功能箭頭函數操作符左邊為輸入的參數,而右邊則是進行的操作以及返回的值。將對象納入規范,提供了原生的對象。增加了和命令,用來聲明變量。 關于ES6的入門了解 新增模板字符串(為JavaScript提供了簡單的字符串插值功能)、箭頭函數(操作符左邊為輸入的參數,而右邊則是進行的操作以及返回的值Inputs=>outputs。)、for-o...
摘要:執行函數會返回一個遍歷器對象,每一次函數里面的都相當一次遍歷器對象的方法,并且可以通過方法傳入自定義的來改變函數的行為。函數可以通過配合函數更輕松更優雅的實現異步編程和控制流管理。它和構造函數的不同點類的內部定義的所有方法,都是不可枚舉的。 let const的命令 在ES6之前,聲明變量只能用var,var方式聲明變量其實是很不合理的,準確的說,是因為ES5里面沒有塊級作用域是很不合...
閱讀 684·2021-09-30 09:47
閱讀 2874·2021-09-04 16:40
閱讀 860·2019-08-30 13:18
閱讀 3455·2019-08-29 16:22
閱讀 1560·2019-08-29 12:36
閱讀 590·2019-08-29 11:11
閱讀 1479·2019-08-26 13:47
閱讀 1134·2019-08-26 13:32