最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

捕獲未處理的Promise錯誤方法

來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:28:01
文檔

捕獲未處理的Promise錯誤方法

捕獲未處理的Promise錯誤方法:為了保證可讀性,本文采用意譯而非直譯,并且對源代碼進行了大量修改。另外,本文版權歸原作者所有,翻譯僅用于學習。 使用Promise編寫異步代碼時,使用reject來處理錯誤。有時,開發(fā)者通常會忽略這一點,導致一些錯誤沒有得到處理。例如: function
推薦度:
導讀捕獲未處理的Promise錯誤方法:為了保證可讀性,本文采用意譯而非直譯,并且對源代碼進行了大量修改。另外,本文版權歸原作者所有,翻譯僅用于學習。 使用Promise編寫異步代碼時,使用reject來處理錯誤。有時,開發(fā)者通常會忽略這一點,導致一些錯誤沒有得到處理。例如: function

為了保證可讀性,本文采用意譯而非直譯,并且對源代碼進行了大量修改。另外,本文版權歸原作者所有,翻譯僅用于學習。

使用Promise編寫異步代碼時,使用reject來處理錯誤。有時,開發(fā)者通常會忽略這一點,導致一些錯誤沒有得到處理。例如:

function main() {
asyncFunc()
.then(···)
.then(() => console.log('Done!'));
}

由于沒有使用catch方法捕獲錯誤,當asyncFunc()函數(shù)reject時,拋出的錯誤則沒有被處理。

這篇博客將分別介紹在瀏覽器與Node.js中,如何捕獲那些未處理的Promise錯誤。

瀏覽器中未處理的Promise錯誤

一些瀏覽器(例如Chrome)能夠捕獲未處理的Promise錯誤。

unhandledrejection

監(jiān)聽unhandledrejection事件,即可捕獲到未處理的Promise錯誤:

window.addEventListener('unhandledrejection', event => ···);

這個事件是PromiseRejectionEvent實例,它有2個最重要的屬性:

promise: reject的Promise

reason: Promise的reject值

示例代碼:

window.addEventListener('unhandledrejection', event =>
{
console.log(event.reason); // 打印"Hello, Fundebug!"
});
 
function foo()
{
Promise.reject('Hello, Fundebug!');
}
 
foo();

Fundebug的JavaScript錯誤監(jiān)控插件監(jiān)聽了unhandledrejection事件,因此可以自動捕獲未處理Promise錯誤。

rejectionhandled

當一個Promise錯誤最初未被處理,但是稍后又得到了處理,則會觸發(fā)rejectionhandled事件:

window.addEventListener('rejectionhandled', event => ···);

這個事件是PromiseRejectionEvent實例。

示例代碼:

window.addEventListener('unhandledrejection', event =>
{
console.log(event.reason); // 打印"Hello, Fundebug!"
});
 
window.addEventListener('rejectionhandled', event =>
{
console.log('rejection handled'); // 1秒后打印"rejection handled"
});
 
 
function foo()
{
return Promise.reject('Hello, Fundebug!');
}
 
var r = foo();
 
setTimeout(() =>
{
r.catch(e =>{});
}, 1000);

Node.js中未處理的Promise錯誤

監(jiān)聽unhandledRejection事件,即可捕獲到未處理的Promise錯誤:

process.on('unhandledRejection', (reason, promise) => ···);

示例代碼:

process.on('unhandledRejection', reason =>
{
console.log(reason); // 打印"Hello, Fundebug!"
});
 
function foo()
{
Promise.reject('Hello, Fundebug!');
}
 
foo();

注: Node.js v6.6.0+ 默認會報告未處理的Promise錯誤,因此不去監(jiān)聽unhandledrejection事件也沒問題。

Fundebug的Node.js錯誤監(jiān)控插件監(jiān)聽了unhandledRejection事件,因此可以自動捕獲未處理Promise錯誤。

以上這篇捕獲未處理的Promise錯誤方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

捕獲未處理的Promise錯誤方法

捕獲未處理的Promise錯誤方法:為了保證可讀性,本文采用意譯而非直譯,并且對源代碼進行了大量修改。另外,本文版權歸原作者所有,翻譯僅用于學習。 使用Promise編寫異步代碼時,使用reject來處理錯誤。有時,開發(fā)者通常會忽略這一點,導致一些錯誤沒有得到處理。例如: function
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top