掌握Node.js中的Promise異步編程方式
介紹
- Promise就是一個用來存儲數(shù)據(jù)的對象
- 但是由于Promise存取方式的特殊,所以可以直接將異步調(diào)用的結(jié)果存儲到Promise中
function sum(a, b) { return new Promise((resolve, reject) => { setTimeout(() => { resolve(a + b) }, 1000) }) } // 返回的是Promise,所以接收的時候不用變量接收,而是采用then獲取Promise存儲的數(shù)據(jù) sum(123, 345).then(result => { console.log("結(jié)果為", result) })
調(diào)用方法就會有返回值,而調(diào)用then、catch、finally三種方法都會產(chǎn)生一個新的Promise
const promise = new Promise((resolve, reject) => { resolve("沒問題的數(shù)據(jù)") }) const p2 = promise.then() console.log(p2)
對Promise進行鏈?zhǔn)秸{(diào)用時,后面的方法(then和catch)讀取的是上一步的執(zhí)行結(jié)果
如果上一步的執(zhí)行結(jié)果不是當(dāng)前想要的結(jié)果,跳過當(dāng)前的方法
const promise = new Promise((resolve, reject) => { reject("沒問題的數(shù)據(jù)") }) // promise的鏈?zhǔn)秸{(diào)用 promise .then(r => console.log("第一個then", r)) .catch(r => { console.log("異常處理", r) return "嘻嘻" }) .then(r => console.log("第二個then", r))
打印結(jié)果為:
異常處理 沒問題的數(shù)據(jù)
第二個then 嘻嘻
上述示例中,reject綁定了異常的數(shù)據(jù),下面的promise調(diào)用的第一個then方法顯然不會接收reject綁定的那個的數(shù)據(jù),即有問題的數(shù)據(jù),所以第一個then被跳過,catch則專門用來接收有問題的數(shù)據(jù)和reject綁定的數(shù)據(jù),所以進入和catch方法并打印 “沒問題的數(shù)據(jù)" ,這個方法的結(jié)尾還有個return,這個return返回的 ”嘻嘻” 顯然是個正常數(shù)據(jù),執(zhí)行完catch后返回了正常數(shù)據(jù) “嘻嘻" 給新的promise,這個正確數(shù)據(jù)又被之后的 then方法捕捉到了,所以會把 ”嘻嘻" 接著打印出來;每次調(diào)用catch、finally、then都會產(chǎn)生一個新的promise
當(dāng)Promise出現(xiàn)異常時,而整個調(diào)用鏈中沒有catch,則異常則會向外拋出
所以一般都會在最后放catch方法,防止會有異常而沒有相應(yīng)的處理方法
靜態(tài)方法
Promise的靜態(tài)方法直接通過Promise類去調(diào)用,這些方法可以幫助我們完成一些更加復(fù)雜的異步操作
Promise.resolve()
創(chuàng)建一個立即完成的Promise
Promise.resolve(10) // 等價于 new Promise((resolve, reject) => { resolve(10) })
Promise.all
- 需要有多個Promise需要執(zhí)行,且需要多個Promise都執(zhí)行完畢,再將結(jié)果進行統(tǒng)一處理,就使用Promise.all來處理
- 語法: Promise.all(iterable)
- Promise.all([...]) 同時但會多個Promise的執(zhí)行結(jié)果,其中有一個報錯,就返回錯誤信息
- all需要一個數(shù)組(可迭代對象) 作為參數(shù),數(shù)組種可以存放多個Promise
function sum(a, b) { return new Promise((reslove, reject) => { setTimeout(() => { reslove(a + b) }, 1000); }) } Promise.all([sum(1, 1), sum(2, 3), sum(3, 3)]) .then((result) => { console.log(result) })
上面的例子中,調(diào)用三次sum,且將其添加到數(shù)組中傳遞給all,調(diào)用all會返回一個新的Promise,當(dāng)三次計算都完成后,新的promise也會變成完成狀態(tài),并將三次執(zhí)行的結(jié)果封裝到數(shù)組中返回。\
// 添加的數(shù)據(jù)中一旦出現(xiàn)一個或者多個reject添加的錯誤信息, 整體的運行結(jié)果就會報錯 Promise.all([sum(1, 1), sum(2, 3), sum(3, 3)], Promise.reject("哈哈")) .then((result) => { console.log(result) })
注意:在all中添加數(shù)據(jù),如果出現(xiàn)了一個或者多個通過reject添加的錯誤信息,運行結(jié)果就會報錯,一個錯,整個就錯
Promise.allsSettled
- Promise.allSettled( [...]) 同時返回多個Promise的運行結(jié)果,無論成功還是失敗
- 但是會根據(jù)不同得到狀態(tài)返回不同的數(shù)據(jù)
成功:{status:”fulfilled”, value:result}
失敗:{status:”rejected”, reason:error}
Promise.race race
- 會返回首先執(zhí)行完的Promise,而忽略其他未執(zhí)行完的Promise
Promise.Any
- any和race類似,但是他只會返回第一個成功的Promise,如果所有的Promise都失敗才會返回一個錯誤信息
到此這篇關(guān)于掌握Node.js中的Promise異步編程方式的文章就介紹到這了,更多相關(guān)Node.js Promise異步內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
node.js入門教程之querystring模塊的使用方法
querystring模塊主要用來解析查詢字符串,下面這篇文章主要介紹了關(guān)于node.js中querystring模塊使用方法的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02關(guān)于node.js版本npm -v報錯問題的解決方法
最近工作中遇到了些問題,這里總結(jié)下,下面這篇文章主要給大家介紹了關(guān)于node.js版本npm -v報錯問題的解決方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04node爬取微博的數(shù)據(jù)的簡單封裝庫nodeweibo使用指南
這篇文章主要介紹了node爬取微博的數(shù)據(jù)的簡單封裝庫nodeweibo使用指南,需要的朋友可以參考下2015-01-01Restify中接入Socket.io報Error:Can’t set headers的錯誤解決
這篇文章主要給大家介紹了在Restify中接入Socket.io報Error:Can’t set headers的錯誤解決方法,文中介紹的非常詳細(xì),對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03nodejs?實現(xiàn)簡單的文件上傳功能(示例詳解)
這篇文章主要介紹了nodejs?實現(xiàn)簡單的文件上傳功能,文件上傳方式分為三種,本文通過實例代碼給大家詳細(xì)介紹,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02