這篇文章主要介紹了JavaScript的Promise類怎么使用的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇JavaScript的Promise類怎么使用文章都會有所收獲,下面我們一起來看看吧。
站在用戶的角度思考問題,與客戶深入溝通,找到蓬溪網(wǎng)站設(shè)計與蓬溪網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、主機(jī)域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋蓬溪地區(qū)。
Promise 類有 .then() .catch() 和 .finally() 三個方法,這三個方法的參數(shù)都是一個函數(shù),.then() 可以將參數(shù)中的函數(shù)添加到當(dāng)前 Promise 的正常執(zhí)行序列,.catch() 則是設(shè)定 Promise 的異常處理序列,.finally() 是在 Promise 執(zhí)行的最后一定會執(zhí)行的序列。 .then() 傳入的函數(shù)會按順序依次執(zhí)行,有任何異常都會直接跳到 catch 序列:
實(shí)例
new Promise(function (resolve, reject) {
console.log(1111);
resolve(2222);
}).then(function (value) {
console.log(value);
return 3333;
}).then(function (value) {
console.log(value);
throw "An error";
}).catch(function (err) {
console.log(err);
});
執(zhí)行結(jié)果:
1111
2222
3333
An error
resolve() 中可以放置一個參數(shù)用于向下一個 then 傳遞一個值,then 中的函數(shù)也可以返回一個值傳遞給 then。但是,如果 then 中返回的是一個 Promise 對象,那么下一個 then 將相當(dāng)于對這個返回的 Promise 進(jìn)行操作,這一點(diǎn)從剛才的計時器的例子中可以看出來。
reject() 參數(shù)中一般會傳遞一個異常給之后的 catch 函數(shù)用于處理異常。
但是請注意以下兩點(diǎn):
resolve 和 reject 的作用域只有起始函數(shù),不包括 then 以及其他序列;
resolve 和 reject 并不能夠使起始函數(shù)停止運(yùn)行,別忘了 return。
關(guān)于“JavaScript的Promise類怎么使用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“JavaScript的Promise類怎么使用”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。