您好,登錄后才能下訂單哦!
這篇文章主要介紹了JavaScript的Promise類(lèi)怎么使用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇JavaScript的Promise類(lèi)怎么使用文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
Promise 類(lèi)有 .then() .catch() 和 .finally() 三個(gè)方法,這三個(gè)方法的參數(shù)都是一個(gè)函數(shù),.then() 可以將參數(shù)中的函數(shù)添加到當(dāng)前 Promise 的正常執(zhí)行序列,.catch() 則是設(shè)定 Promise 的異常處理序列,.finally() 是在 Promise 執(zhí)行的最后一定會(huì)執(zhí)行的序列。 .then() 傳入的函數(shù)會(huì)按順序依次執(zhí)行,有任何異常都會(huì)直接跳到 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() 中可以放置一個(gè)參數(shù)用于向下一個(gè) then 傳遞一個(gè)值,then 中的函數(shù)也可以返回一個(gè)值傳遞給 then。但是,如果 then 中返回的是一個(gè) Promise 對(duì)象,那么下一個(gè) then 將相當(dāng)于對(duì)這個(gè)返回的 Promise 進(jìn)行操作,這一點(diǎn)從剛才的計(jì)時(shí)器的例子中可以看出來(lái)。
reject() 參數(shù)中一般會(huì)傳遞一個(gè)異常給之后的 catch 函數(shù)用于處理異常。
但是請(qǐng)注意以下兩點(diǎn):
resolve 和 reject 的作用域只有起始函數(shù),不包括 then 以及其他序列;
resolve 和 reject 并不能夠使起始函數(shù)停止運(yùn)行,別忘了 return。
關(guān)于“JavaScript的Promise類(lèi)怎么使用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“JavaScript的Promise類(lèi)怎么使用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。