Promise拋出錯誤解決基礎(chǔ)示例詳解
then
then
函數(shù)的會接收兩個回調(diào)函數(shù),一個是 onFulfilled
函數(shù),一個是 onRejected
函數(shù)
如果這兩個回調(diào)函數(shù)沒有寫返回值,默認(rèn)會 return undefined;
進入下一個函數(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); } );
在這兩個回調(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")); // 等價于 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
拋出錯誤可以
const p = new Promise((resolve, reject) => { resolve(22); }); p.then( (success1) => { return new Promise((resolve, reject) => reject("error")); // 等價于 // 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
會被自動包裝成 return new Promise((resolve) => resolve(xxx));
,
catch
catch
是用來處理 rejected
狀態(tài),是 then
函數(shù)的一種特例,相當(dāng)于 then(null, (err) => {});
catch
為什么能捕獲前面的錯誤?
在 onRejected
函數(shù)中,如果沒有顯示拋出錯誤,默認(rèn)會 return undefined;
進入一下個 onFulfilled
函數(shù)
finally
finally
不管當(dāng)前 promise
是什么狀態(tài)都會執(zhí)行,也是 then
函數(shù)的一種特例,相當(dāng)于 `then(result => result, err => new Promsie((_, reject) => reject(err)));
Promise.resolve
Promise.resolve
是 Promise
在 fulfilled
狀態(tài)時的簡寫,相當(dāng)于 new Promise(resolve => resolve(xxx))
onFulfilled
函數(shù)接收參數(shù)
當(dāng)參數(shù)是普通參數(shù)時,會直接傳遞給后面 then
函數(shù)
new Promise((resolve) => resolve({ name: "uccs" })).then((data) => { console.log(data); });
當(dāng)參數(shù)是 Promise
對象時,后面的 then
會根據(jù)傳遞的 Promise
對象的狀態(tài)變化執(zhí)行哪一個回調(diào)
const p = new Promise((resolve, reject) => { setTimeout(resolve, 1000, "我執(zhí)行了"); }); new Promise((resolve) => resolve(p)).then((data) => { console.log(data); });
具有 then
方法的對象
const thenable = { then(resolve, reject) { console.log("thenable"); }, }; new Promise((resolve) => resolve(thenable)).then((data) => { console.log(data); });
- 用這種這種方式,如果需要改變
Promise
狀態(tài)是,不能使用return
形式,這個then
方法也是有兩個回調(diào)函數(shù)的:onFulfilled
和onRejected
Promise.reject
Promise.reject
是 Promise
在 rejected
狀態(tài)是的簡寫,相當(dāng)于 new Promise((_, reject) => reject(xxx))
onRejected
函數(shù)不管接收什么參數(shù),都會原封不動的向后傳遞,作為后續(xù)方法的參數(shù)
以上就是Promise拋出錯誤解決基礎(chǔ)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Promise拋出錯誤解決的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09JS提示:Uncaught SyntaxError:Unexpected token ) 錯誤的解決方法
這篇文章主要介紹了JS提示:Uncaught SyntaxError:Unexpected token ) 錯誤的解決方法,結(jié)合實例形式分析了javascript提示此類異常的常見原因與相關(guān)解決方法,需要的朋友可以參考下2016-08-08