日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解JavaScript錯誤捕獲

瀏覽:23日期:2023-10-02 17:23:41
一、基本使用與邏輯

使用

try{ //code....}catch(err){ //error handling}finally{ //no matter what happens in the try/catch (error or no error), this code in the finally statement should run. }

邏輯

詳解JavaScript錯誤捕獲

二、特性

try...catch 僅適用于運行時錯誤,解釋階段錯誤無法正常工作

try{ {{{{{{{}catch(err){ console.error(err)}//引擎在‘parse-time’出錯,導致無法理解代碼,因此無法捕捉

try...catch 只能同步工作

try{ setTimeout(function(){undefinedVariable; },1000)}catch(err){ console.error(err)}//setTimeout的回調函數執行時,引擎已經離開try...catch結構

finally 能讓try塊中的return語句失效

function test(){ try { return 1; } catch(error) { return 2; } finally { return 3; }}console.log(test());//3三、錯誤對象

當程序發生error,js內部會生成一個包含error細節的對象,該對象會被作為參數傳進catch

對于所有內置錯誤,錯誤對象具有兩個主要屬性

name 錯誤類型 message 文本類型的錯誤信息 stack (非標準屬性)發生錯誤時的調用棧信息,主要用于調試

try { lalala; // error, variable is not defined!} catch (err) { alert(err.name); // ReferenceError alert(err.message); // lalala is not defined alert(err.stack); // ReferenceError: lalala is not defined at (...call stack) // Can also show an error as a whole // The error is converted to string as 'name: message' alert(err); // ReferenceError: lalala is not defined}

理論上,我們可以throw任何東西作為錯誤對象,但最好的習慣是throw一個具有name,message的對象,以便和內置錯誤對象保持兼容

番外:內置的錯誤對象

對象 含義 ReferenceError 引用未定義變量時觸發 SyntaxError 使用不合法的語法結構時觸發 TypeError 值得類型非預期時觸發 URIError 錯誤使用全局URI函數如encodeURI()、decodeURI()等時觸發 RangeError 對Array構造函數使用錯誤的長度值,對Number.toExponential()、Number.toFixed()或Number.toPrecision()使用無效數字等 EvalError 全局函數eval()中發生的錯誤 四、較好的catch和throw策略

​ catch錯誤不單單是為了防止程序掛掉,更重要的目的是方便調試,找bug,所以對錯誤的處理策略,稍微可以體現出碼者的優雅性

​ 俗話說的好,碼者,人恒雅也,盡量遵循一個原則,catch只處理自己知道的錯誤

舉個梨子

let json = ’{ 'age': 30 }’; try{ let user = JSON.parse(json); alert( user.name );} catch (err) { console.error(’JSON Error:’+err);}

上述例子的catch策略能保證程序正常,因為catch塊能catch內部所有的錯誤,無論是JSON.parse出錯還是user.name不存在報錯,都能被catch到,但兩種錯誤都用同一種打印是不利于調試的,寫成下面這樣會好一點

let json = ’{'age':30}’try{ let user = JSON.parse(json); alert(user.name)}catch(err){ if(err instanceof SyntaxError){ console.error(’JSON Error:’+err); } else throw err;}

每個catch塊處理自己知道得,可能會出現得錯誤,就是說,編程人員在編程的時候,catch那些預料到的錯誤,而將可能自己沒料到的錯誤拋到外面。

五、Promise的錯誤處理

​ 眾所周知,Promise是會吞掉error的,因為promise的實現就在內部對所有error進行了捕獲,且捕獲到的error不是向外拋出(外指promise之外),而是沿著鏈找到最近的onreject回調傳入,所以promise的錯誤處理只有兩種辦法

設置onreject回調 全局捕獲

舉個栗子

try{ new Promise((resolve,reject)=>{throw new Error(’promise error’) }).catch(()=>{//錯誤在最近的onreject回調被捕獲console.error(err); })}catch(err){ //永遠不會執行,promise吞掉error console.error(err);}

另外需要注意,無論是執行者函數(executor)和還是 promise 的處理程序(handler),內部發生的錯誤統統吞掉,相當于被隱式catch,error會自動找到最近的onreject回調傳進去

try{ new Promise((resolve,reject)=>{resolve(); }).then(()=>{throw new Error(’promise then error’); }).catch((err){console.error(err); })}catch(err){ //地球毀滅之前都不會執行 console.error(err)}

同理,在錯誤找到onreject傳進去之前,經過的then注冊的onfulfilled回調統統失效,直到找到onreject回調,處理之后,onreject回調之后的onfulfilled回調才正常

try { new Promise((resolve, reject) => {throw new Error(’promise error’) }).then((ret) => {//錯誤沒有處理,失效console.log(’then1:’ + ret) }).catch((err) => {//錯誤處理了,后序正常console.error(err);return ’handled’ }).then((ret) => {//正常執行console.log(’then2’ + ret); })} catch (err) { //同樣的,人類毀滅之前都不會執行 console.error(err)}// Error:promise error//then2handled

那整條鏈一個catch都沒設置會怎么樣呢?

那這個error就會擊穿地心,一直穿透到全局,根據宿主環境的不同觸發不同的全局事件,比如說瀏覽器中會觸發 unhandledrejection事件,node環境中也會觸發unhandledRejection事件,一般會對這事件進行監聽,再顯示信息給編程人員或者用戶

番外1:chromium / v8 / v8 / 3.29.45 的 Promise內部錯誤捕捉

詳解JavaScript錯誤捕獲

番外2:async/await錯誤捕捉

六、性能損耗​

After V8 version 6 (shipped with Node 8.3 and latest Chrome), the performance of code inside try-catch is the same as that of normal code. ------ 爆棧網

(稍微測了一下,相差無幾)

以上就是詳解JavaScript錯誤捕獲的詳細內容,更多關于JavaScript 錯誤捕獲的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品jk白丝蜜臀av小说| 国产中文欧美日韩在线| 国产精品视频一区二区三区四蜜臂 | 黄色成人91| 国产麻豆久久| 亚洲一区不卡| 国产精品资源| 高清不卡亚洲| 亚洲国产专区| 偷拍亚洲精品| 国产成人精品亚洲线观看 | 老牛影视一区二区三区| 久久国产尿小便嘘嘘| 视频在线不卡免费观看| 久久www成人_看片免费不卡| 91欧美极品| 极品日韩av| 91精品国产自产观看在线| 成人综合一区| 美国三级日本三级久久99| 欧美精品91| 久久高清精品| 911精品国产| 久久精品国产大片免费观看| 91嫩草精品| 婷婷丁香综合| 欧美好骚综合网| 亚洲精品女人| 亚洲午夜黄色| 成人国产精品一区二区免费麻豆| 麻豆精品91| 亚洲四虎影院| 国产探花在线精品| 久久国产精品久久w女人spa| 成人黄色av| 久久国产免费看| 欧美日韩国产一区精品一区| 超碰99在线| 国产精品美女在线观看直播| 丝袜诱惑制服诱惑色一区在线观看 | 久久精品91| 91p九色成人| 日本大胆欧美人术艺术动态| 欧美日韩中文字幕一区二区三区| 91成人精品观看| 久久xxxx| 玖玖精品视频| 久久不射网站| 亚洲综合国产| 国产婷婷精品| 在线精品一区二区| aⅴ色国产欧美| 亚洲欧洲一区| 免费欧美日韩| 三级亚洲高清视频| 石原莉奈一区二区三区在线观看| 五月天激情综合网| 欧美日韩免费观看一区=区三区| 久久精品成人| 精品一区在线| 香蕉视频亚洲一级| 日韩欧美看国产| 婷婷综合激情| 涩涩涩久久久成人精品| 欧美亚洲国产日韩| 免费精品一区| 亚洲成av在线| 美女网站久久| 国产精品一区二区精品| 精品欧美日韩精品| 高清av一区二区三区| 欧美成人综合| 日韩中文av| 精品国产精品国产偷麻豆 | 三级欧美韩日大片在线看| 亚洲美女久久| 成人污污视频| 欧美午夜不卡影院在线观看完整版免费| 爽好多水快深点欧美视频| 久久不见久久见国语| 99视频精品全国免费| 日韩激情中文字幕| 午夜av不卡| 青青草伊人久久| japanese国产精品| 国产精品视频一区二区三区综合| 黄色aa久久| 日韩精品免费视频人成| 成人午夜在线| 蜜桃视频一区二区| 蜜桃视频在线网站| 欧美另类中文字幕| 亚洲精品中文字幕乱码| 欧美成人一二区| 久久亚洲精品伦理| 国产欧美一区二区三区精品酒店| 亚洲三级观看| 在线日韩一区| 欧美韩日一区| 日韩va欧美va亚洲va久久| 亚洲精品a级片| 天堂av在线| 精品视频自拍| 日本国产欧美| 亚洲精品小说| 精品亚洲美女网站| 精品日本视频| 久久精品国产99| 日本少妇精品亚洲第一区| 蜜桃成人av| 欧美成人a交片免费看| 你懂的国产精品| 欧美在线黄色| 日韩国产在线观看一区| 欧美专区在线| 中文在线日韩| 日日夜夜免费精品视频| 亚洲天堂av资源在线观看| 午夜亚洲精品| 亚洲婷婷在线| 伊人久久成人| 视频精品一区二区| 亚洲乱亚洲高清| 日本aⅴ免费视频一区二区三区| 热久久久久久久| 亚洲精品在线二区| 日韩欧美中文字幕电影| 欧美日韩精品一区二区三区视频| 91福利精品在线观看| 国产精品一区二区三区www| 久久成人高清| 久久久久久色| 国产日韩视频在线| 精品久久精品| 捆绑调教日本一区二区三区| 久久三级福利| 涩涩涩久久久成人精品| 久久99国产精品视频| 国产超碰精品| 蜜桃久久久久久| 鲁大师精品99久久久| 99久久夜色精品国产亚洲狼 | 午夜一级在线看亚洲| 日韩国产一区二| 中文一区一区三区高中清不卡免费| 成人一区而且| 久久av在线| 另类欧美日韩国产在线| 亚洲精品一区二区妖精| 欧美精品观看| 蜜臀av免费一区二区三区| 日韩三区四区| 91精品国产调教在线观看| 中文字幕免费一区二区| 中文字幕在线看片| 日本免费新一区视频| 久久国产欧美| 免费在线亚洲欧美| 日本欧洲一区二区| 免费一二一二在线视频| 石原莉奈在线亚洲二区| 麻豆成全视频免费观看在线看| 在线国产一区| 国产粉嫩在线观看| 久久精品97| 免费看黄色91| 激情综合网五月| 国产一区二区三区黄网站| 亚洲另类视频| 亚洲精品午夜av福利久久蜜桃| 精品三级av| 国产精品v一区二区三区| 亚洲伊人影院| 亚洲一区二区三区高清| 久久久久国产精品一区二区| 日韩1区2区3区| 欧美专区在线| 成人av动漫在线观看| 天堂av在线| 黑人精品一区| 中文字幕色婷婷在线视频| 国产精品亲子伦av一区二区三区| 亚洲午夜免费| 视频一区欧美精品| 在线亚洲成人| 五月天综合网站| 日韩午夜黄色| 免费观看日韩电影| 视频一区二区三区入口| 视频在线观看一区二区三区| 99久久www免费| 香蕉国产精品| 亚洲少妇诱惑| 婷婷综合成人| 国产乱码精品一区二区三区四区 | 日韩精品电影一区亚洲| 妖精视频成人观看www| 国产精品视区| 日韩久久99| 精品美女视频|