Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解
then
then
函數(shù)的會(huì)接收兩個(gè)回調(diào)函數(shù),一個(gè)是 onFulfilled
函數(shù),一個(gè)是 onRejected
函數(shù)
如果這兩個(gè)回調(diào)函數(shù)沒(méi)有寫(xiě)返回值,默認(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 // 沒(méi)寫(xiě) 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
是用來(lái)處理 rejected
狀態(tài),是 then
函數(shù)的一種特例,相當(dāng)于 then(null, (err) => {});
catch
為什么能捕獲前面的錯(cuò)誤?
在 onRejected
函數(shù)中,如果沒(méi)有顯示拋出錯(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)寫(xiě),相當(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)寫(xiě),相當(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)文章
JavaScript編寫(xiě)開(kāi)發(fā)動(dòng)態(tài)時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了JavaScript編寫(xiě)開(kāi)發(fā)動(dòng)態(tài)時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07JS簡(jiǎn)單實(shí)現(xiàn)文件上傳實(shí)例代碼(無(wú)需插件)
注意一下:在chrome瀏覽器下,為了數(shù)據(jù)安全,隱藏的input:file不能trigger “click” 事件。 所以要設(shè)置input:file的透明度達(dá)到隱藏的效果2013-11-11函數(shù)式 JavaScript(一)簡(jiǎn)介
JavaScript 是一種強(qiáng)大但被誤解的語(yǔ)言。關(guān)于它到底是一種面向?qū)ο蟮恼Z(yǔ)言還是函數(shù)式語(yǔ)言,人們眾說(shuō)紛紜——但是現(xiàn)在讓我們把這些爭(zhēng)辯都拋到腦后。2014-07-07JavaScript使用Proxy編寫(xiě)一個(gè)取值限制器
最近一直在開(kāi)發(fā)低代碼平臺(tái)的東西,由于項(xiàng)目里面東西有點(diǎn)多,取值或調(diào)用起來(lái)比較麻煩,使用本文就將使用Proxy編寫(xiě)一個(gè)取值限制器,需要的小伙伴可以參考下2023-12-12微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實(shí)例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09JS提示:Uncaught SyntaxError:Unexpected token ) 錯(cuò)誤的解決方法
這篇文章主要介紹了JS提示:Uncaught SyntaxError:Unexpected token ) 錯(cuò)誤的解決方法,結(jié)合實(shí)例形式分析了javascript提示此類(lèi)異常的常見(jiàn)原因與相關(guān)解決方法,需要的朋友可以參考下2016-08-08JS實(shí)現(xiàn)移動(dòng)端判斷上拉和下滑功能
通過(guò)手指觸屏,利用touchstart和touchend計(jì)算前后滑動(dòng)距離,判斷是上拉還是下滑。接下來(lái)通過(guò)實(shí)例代碼給大家介紹js移動(dòng)端判斷上拉和下滑功能,感興趣的朋友一起看看吧2017-08-08