Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解
then
then 函數(shù)的會(huì)接收兩個(gè)回調(diào)函數(shù),一個(gè)是 onFulfilled 函數(shù),一個(gè)是 onRejected 函數(shù)
如果這兩個(gè)回調(diào)函數(shù)沒有寫返回值,默認(rèn)會(huì) return undefined;
進(jìn)入下一個(gè)函數(shù)的 onFulfilled 函數(shù)中
const p = new Promise((resolve, reject) => {
resolve(22);
});
p.then(
(success1) => {
console.log("success1", success1); // "success2" 22
// 沒寫 return 默認(rèn)返回 return undefined
},
(err1) => {
console.log("err1", err1);
}
).then(
(success2) => {
console.log("success2", success2); // "success2" undefined
},
(err2) => {
console.log("err2", err2);
}
);
在這兩個(gè)回調(diào)中 return xxx ,相當(dāng)于調(diào)用 return new Promise((resolve) => resolve(xxx));
const p = new Promise((resolve, reject) => {
resolve(22);
});
p.then(
(success1) => {
return new Promise((resolve, reject) => resolve("success"));
// 等價(jià)于
return "success";
},
(err1) => {
console.log("err1", err1);
}
).then(
(success2) => {
console.log("success2", success2); // "success2" "success"
},
(err2) => {
console.log("err2", err2);
}
);
在 onFulfilled 函數(shù)和 onRejected 函數(shù)中默認(rèn)返回的都是成功,如果需要返回失敗需要顯示調(diào)用 reject 或者用 throw 拋出錯(cuò)誤可以
const p = new Promise((resolve, reject) => {
resolve(22);
});
p.then(
(success1) => {
return new Promise((resolve, reject) => reject("error"));
// 等價(jià)于
// throw "error";
},
(err1) => {
console.log("err1", err1);
}
).then(
(success2) => {
console.log("success2", success2);
},
(err2) => {
console.log("err2", err2); // "err2" error
}
);
總結(jié):在 then 回調(diào)中 return xxx 會(huì)被自動(dòng)包裝成 return new Promise((resolve) => resolve(xxx));,
catch
catch 是用來處理 rejected 狀態(tài),是 then 函數(shù)的一種特例,相當(dāng)于 then(null, (err) => {});
catch 為什么能捕獲前面的錯(cuò)誤?
在 onRejected 函數(shù)中,如果沒有顯示拋出錯(cuò)誤,默認(rèn)會(huì) return undefined; 進(jìn)入一下個(gè) onFulfilled 函數(shù)
finally
finally 不管當(dāng)前 promise 是什么狀態(tài)都會(huì)執(zhí)行,也是 then 函數(shù)的一種特例,相當(dāng)于 `then(result => result, err => new Promsie((_, reject) => reject(err)));
Promise.resolve
Promise.resolve 是 Promise 在 fulfilled 狀態(tài)時(shí)的簡(jiǎn)寫,相當(dāng)于 new Promise(resolve => resolve(xxx))
onFulfilled 函數(shù)接收參數(shù)
當(dāng)參數(shù)是普通參數(shù)時(shí),會(huì)直接傳遞給后面 then 函數(shù)
new Promise((resolve) => resolve({ name: "uccs" })).then((data) => {
console.log(data);
});
當(dāng)參數(shù)是 Promise 對(duì)象時(shí),后面的 then 會(huì)根據(jù)傳遞的 Promise 對(duì)象的狀態(tài)變化執(zhí)行哪一個(gè)回調(diào)
const p = new Promise((resolve, reject) => {
setTimeout(resolve, 1000, "我執(zhí)行了");
});
new Promise((resolve) => resolve(p)).then((data) => {
console.log(data);
});
具有 then 方法的對(duì)象
const thenable = {
then(resolve, reject) {
console.log("thenable");
},
};
new Promise((resolve) => resolve(thenable)).then((data) => {
console.log(data);
});
- 用這種這種方式,如果需要改變
Promise狀態(tài)是,不能使用return形式,這個(gè)then方法也是有兩個(gè)回調(diào)函數(shù)的:onFulfilled和onRejected
Promise.reject
Promise.reject 是 Promise 在 rejected 狀態(tài)是的簡(jiǎn)寫,相當(dāng)于 new Promise((_, reject) => reject(xxx))
onRejected 函數(shù)不管接收什么參數(shù),都會(huì)原封不動(dòng)的向后傳遞,作為后續(xù)方法的參數(shù)
以上就是Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Promise拋出錯(cuò)誤解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解JS如何使用Promise緩存網(wǎng)絡(luò)請(qǐng)求
網(wǎng)絡(luò)請(qǐng)求是現(xiàn)代Web應(yīng)用中的常見操作,很多時(shí)候需要獲取服務(wù)器上的數(shù)據(jù),在進(jìn)行網(wǎng)絡(luò)請(qǐng)求時(shí),為了減輕服務(wù)器的壓力,緩存策略常被用來避免對(duì)同一數(shù)據(jù)的重復(fù)請(qǐng)求,本文將探討如何使用Promise結(jié)合緩存來高效處理網(wǎng)絡(luò)請(qǐng)求,需要的朋友可以參考下2023-12-12
詳解微信小程序工程化探索之webpack實(shí)戰(zhàn)
這篇文章主要介紹了詳解微信小程序工程化探索之webpack實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
詳解layui?laydate選擇時(shí)間的回調(diào)方法
這篇文章主要介紹了layui?laydate選擇時(shí)間的回調(diào)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
js對(duì)象實(shí)例詳解(JavaScript對(duì)象深度剖析,深度理解js對(duì)象)
下面小編就為大家?guī)硪黄猨s對(duì)象實(shí)例詳解(JavaScript對(duì)象深度剖析,深度理解js對(duì)象)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
JavaScript日期時(shí)間與時(shí)間戳的轉(zhuǎn)換函數(shù)分享
這篇文章主要介紹了JavaScript日期時(shí)間與時(shí)間戳的轉(zhuǎn)換函數(shù)分享,本文給出兩個(gè)函數(shù)實(shí)現(xiàn)日期時(shí)間和時(shí)間戳間的轉(zhuǎn)換,需要的朋友可以參考下2015-01-01
BootstrapValidator超詳細(xì)教程(推薦)
這篇文章主要介紹了BootstrapValidator超詳細(xì)教程(推薦)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12
js通過地址欄給action傳值(中文亂碼全是問號(hào))
我從js代碼中通過地址欄傳值給了action的相應(yīng)變量,但是,如果變量值為中文的時(shí)候,在action中測(cè)試輸出則為問號(hào)2013-05-05

