欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Promise拋出錯誤解決基礎(chǔ)示例詳解

 更新時間:2022年12月15日 09:25:33   作者:uccs  
這篇文章主要為大家介紹了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.resolvePromisefulfilled 狀態(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ù)的:onFulfilledonRejected

Promise.reject

Promise.rejectPromiserejected 狀態(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)文章

  • JavaScript編寫開發(fā)動態(tài)時鐘

    JavaScript編寫開發(fā)動態(tài)時鐘

    這篇文章主要為大家詳細(xì)介紹了JavaScript編寫開發(fā)動態(tài)時鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • JS簡單實現(xiàn)文件上傳實例代碼(無需插件)

    JS簡單實現(xiàn)文件上傳實例代碼(無需插件)

    注意一下:在chrome瀏覽器下,為了數(shù)據(jù)安全,隱藏的input:file不能trigger “click” 事件。 所以要設(shè)置input:file的透明度達(dá)到隱藏的效果
    2013-11-11
  • 函數(shù)式 JavaScript(一)簡介

    函數(shù)式 JavaScript(一)簡介

    JavaScript 是一種強大但被誤解的語言。關(guān)于它到底是一種面向?qū)ο蟮恼Z言還是函數(shù)式語言,人們眾說紛紜——但是現(xiàn)在讓我們把這些爭辯都拋到腦后。
    2014-07-07
  • JavaScript使用Proxy編寫一個取值限制器

    JavaScript使用Proxy編寫一個取值限制器

    最近一直在開發(fā)低代碼平臺的東西,由于項目里面東西有點多,取值或調(diào)用起來比較麻煩,使用本文就將使用Proxy編寫一個取值限制器,需要的小伙伴可以參考下
    2023-12-12
  • 很棒的js選項卡切換效果

    很棒的js選項卡切換效果

    很棒的JavaScript選項卡切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實例代碼

    微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實例代碼

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • JS提示:Uncaught SyntaxError:Unexpected token ) 錯誤的解決方法

    JS提示:Uncaught SyntaxError:Unexpected token ) 錯誤的解決方法

    這篇文章主要介紹了JS提示:Uncaught SyntaxError:Unexpected token ) 錯誤的解決方法,結(jié)合實例形式分析了javascript提示此類異常的常見原因與相關(guān)解決方法,需要的朋友可以參考下
    2016-08-08
  • Js獲取圖片原始寬高的實現(xiàn)代碼

    Js獲取圖片原始寬高的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄狫s獲取圖片原始寬高的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • JS實現(xiàn)移動端判斷上拉和下滑功能

    JS實現(xiàn)移動端判斷上拉和下滑功能

    通過手指觸屏,利用touchstart和touchend計算前后滑動距離,判斷是上拉還是下滑。接下來通過實例代碼給大家介紹js移動端判斷上拉和下滑功能,感興趣的朋友一起看看吧
    2017-08-08
  • IE 當(dāng)eval遇上function的處理

    IE 當(dāng)eval遇上function的處理

    在IE下,當(dāng)eval遇上function,IE下會出現(xiàn)怪異情況,我們用例子一步步說明
    2011-08-08

最新評論