日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
JavaScript中的錯誤:為何優(yōu)先處理這些錯誤?

本文轉(zhuǎn)載自公眾號“讀芯術(shù)”(ID:AI_Discovery)。

成都創(chuàng)新互聯(lián)始終堅(jiān)持【策劃先行,效果至上】的經(jīng)營理念,通過多達(dá)十載累計超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的營銷解決方案,現(xiàn)已廣泛運(yùn)用于各行各業(yè)的客戶,其中包括:成都紗窗等企業(yè),備受客戶贊美。

事情的發(fā)展并非總是如愿以償。當(dāng)出問題時,我們會經(jīng)由錯誤得到提示。任何一位開發(fā)者都應(yīng)該對錯誤的概念了如指掌,前端開發(fā)者一定熟知網(wǎng)絡(luò)應(yīng)用程序運(yùn)行時瀏覽器控制臺中通知錯誤的紅色文本警示。

錯誤術(shù)語和異常處理機(jī)制術(shù)語在編程中的應(yīng)用屢見不鮮,但它們往往交替使用。筆者認(rèn)為,錯誤由JavaScript引擎拋出,異常處理機(jī)制則由開發(fā)者拋出。但這種情況在Java編程語言中也許不會出現(xiàn),在Java中,錯誤屬于未檢驗(yàn)類型,在運(yùn)行時出現(xiàn);而異常處理機(jī)制可在運(yùn)行時或編譯時出現(xiàn)。

JavaScript中的錯誤類型

作為動態(tài)類型語言,JavaScript在運(yùn)行前不會警示類型錯誤。錯誤雖然通常歸屬于JavaScript中的Error對象,但是錯誤可進(jìn)一步分類。這些分支繼承了Error對象的特點(diǎn)。

  • EvalError:表示使用全局函數(shù)eval()時拋出的錯誤。
  • InternalError:表示因內(nèi)部錯誤而被JavaScript引擎拋出的錯誤。一個典型的例子:“遞歸方法過多”或一些東西過大的情形。
  • RangeError:表示數(shù)值超出范圍時拋出的錯誤。
  • ReferenceError:表示引用的變量無法取消時拋出的錯誤。換句話說,引用的變量無法找到或無法訪問。
  • SyntaxError:表示因輸入了無效的句法,JavaScript引擎無法解釋給定的代碼而拋出的錯誤。新手們常常遇到此類錯誤。
  • Type Error:通常表示因在操作中使用了無效的數(shù)據(jù)類型,致使操作指令無法執(zhí)行而拋出的錯誤。
  • URIError:表示函數(shù)encodeURI()或decodeURI()接收了無效的參數(shù)而拋出的錯誤。

什么是錯誤處理?

程序通常包括兩類主要問題,程序員錯誤和精度問題。程序員錯誤指的是程序員在寫代碼時做了蠢事,比如說忘記使用正確的變量。精度問題是客觀因素引發(fā)的問題,比如說因網(wǎng)速慢導(dǎo)致數(shù)據(jù)庫連接失敗。

第一類問題可以通過查找并修復(fù)得到處理,但第二類問題只能通過預(yù)防性措施或積極主動的措施得到修復(fù)。這意味著在寫代碼時要考慮到最壞的可能性并將它們妥善處理。這可以是在任何性質(zhì)的錯誤發(fā)生時執(zhí)行的常規(guī)操作,也可以是針對特定錯誤類型執(zhí)行的特定操作。這種防御性措施被稱為錯誤處理。

為何首先處理錯誤?

為了了解為何錯誤處理至關(guān)重要,我們來設(shè)想如下情境:若未能妥善處理錯誤,將會發(fā)生什么?設(shè)想已布置網(wǎng)絡(luò)的應(yīng)用程序未安置錯誤處理。有許多錯誤的出現(xiàn)在開發(fā)者預(yù)期之外,以用戶嘗試上傳格式錯誤的文件為例,如果這種情況未經(jīng)提前處理:

  • 文件上傳失敗
  • 用戶無從得知為何會失敗(除非他們能打開瀏覽器控制臺一探究竟)
  • 用戶很可能今后因?yàn)樯鲜鰡栴}不會訪問網(wǎng)站
  • 作為一名開發(fā)者無從得知為何在這種特殊情況下程序會停止運(yùn)行

如果采用合適的錯誤處理方法,上述諸多問題就不會產(chǎn)生?!昂线m的”指的是錯誤產(chǎn)生時的適當(dāng)處理方法。程序員處理了錯誤,但并未“合適地”處理錯誤,這是網(wǎng)絡(luò)應(yīng)用程序的現(xiàn)存問題之一。

每當(dāng)錯誤產(chǎn)生,許多網(wǎng)站通常會顯示錯誤信息。這理應(yīng)為最終的處理方法,但是大多數(shù)缺少經(jīng)驗(yàn)的開發(fā)者會首先采用這種方法。理想的處理方法是用合適的處理方法處理每一處錯誤,而非治標(biāo)不治本。在實(shí)際的情境中,可能不會在特定的用戶體驗(yàn)中考慮到所有可能的情境。

但是有時,告知用戶特別的錯誤也許不是個好主意,因?yàn)檫@對于普通用戶來說過于復(fù)雜。在這些情況下,可以將一個錯誤的代碼提供給用戶,他們會將代碼發(fā)送給客戶服務(wù)團(tuán)隊(duì),這個團(tuán)隊(duì)能夠參照錯誤代碼指導(dǎo)相應(yīng)的用戶。

錯誤處理對錯誤記錄來說至關(guān)重要,因?yàn)槿绻皇紫忍幚礤e誤,就無法記錄錯誤。筆者認(rèn)為,每一位開發(fā)者都需要精通錯誤記錄。

錯誤處理的方法

下文列舉了JavaScript中的錯誤處理方法。一些是同步的,另一些是異步的。

(1) try-catch

try-catch方法運(yùn)行代碼塊語句并“捕獲”代碼塊拋出的任何錯誤。如果在代碼語句運(yùn)行過程中發(fā)生錯誤,代碼執(zhí)行流將停止并移動至catch代碼塊中的語句,從而能夠適當(dāng)?shù)靥幚磉@些錯誤。try-catch代碼塊可用于處理同步和異步代碼。

 
 
 
 
  1. try { 
  2.    
  3.   console.log(unknownVariable); 
  4.    
  5. } catch (error) { 
  6.    
  7.   console.log(error); 
  8.   //ReferenceError: unknownVariable isnot defined 
  9.    

(2) Promise catch

引入Promises令JavaScript煥然一新。當(dāng)Promise拋出錯誤時,我們可以使用catch方法來處理該錯誤。這與try-catch方法相似,但是該方法中沒有try代碼塊。

(3) Callback error

在傳統(tǒng)Node APIs中,callback用于處理響應(yīng)和錯誤。通常,callback的模式是callback(err,res),其中僅“err”或“res”是非空值。

如上方所示,如果異步函數(shù)失敗,err參數(shù)將接收一個錯誤,這個錯誤應(yīng)適當(dāng)處理。

(4) Error event

這是NodeJS中常見的事件處理模式,在錯誤產(chǎn)生的情況下會觸發(fā)一個error事件。

由于80端口是HTTP的默認(rèn)端口,上面的代碼片段無法創(chuàng)建服務(wù)器,因此會拋出一個錯誤。

(5) Onerror

HTML元素包含一些事件,例如onclick, onchange等。當(dāng)DOM元素拋出錯誤時,將觸發(fā)onerror事件。此外,每當(dāng)JavaScript發(fā)生運(yùn)行錯誤,window對象將觸發(fā)onerror事件。

 
 
 
 
  1. window.onerror = function(message, source, lineno, colno, error) { 
  2.   //handle error 
  3. };element.error = function(event) { 
  4.   //handle element error 

錯誤邊界 — React

React中的錯誤邊界允許JavaScript的錯誤在直觀視圖結(jié)構(gòu)中得到處理,而不會向用戶顯示損壞的UI。只需定義一個名為componentDidCatch(error,info)的全新生命周期方法,就可以創(chuàng)建這些React組件。

錯誤處理是編程的重要一環(huán),要想構(gòu)建高效的應(yīng)用程序,你需要認(rèn)真對待它。


網(wǎng)頁標(biāo)題:JavaScript中的錯誤:為何優(yōu)先處理這些錯誤?
標(biāo)題URL:http://www.5511xx.com/article/coesicd.html