国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

javascript錯(cuò)誤處理類(lèi)型

lylwyy2016 / 2627人閱讀

摘要:來(lái)聊一聊每一種錯(cuò)誤類(lèi)型的使用和出錯(cuò)的場(chǎng)景。不屬于有效類(lèi)型。例如拋出錯(cuò)誤自定義錯(cuò)誤類(lèi)型有時(shí)候希望自定義錯(cuò)誤類(lèi)型,需要自定義一個(gè)構(gòu)造函數(shù),然后讓原型繼承繼承即可。例如以下調(diào)用錯(cuò)誤信息為以上為拋錯(cuò)的構(gòu)造函數(shù)的總結(jié),如有誤之處歡迎扶正。

在寫(xiě)javascript的時(shí)候,調(diào)試錯(cuò)誤必不可少,除了能夠在瀏覽器中打印出來(lái)錯(cuò)誤外,常常還需要知道錯(cuò)誤的類(lèi)型是什么,以便對(duì)癥下藥的糾錯(cuò);也有時(shí)候,在自己封裝的工具函數(shù)中,不傳參或傳入了錯(cuò)誤類(lèi)型的參數(shù),也要適當(dāng)?shù)膾伋鲆恍╁e(cuò)誤以示警告;使用框架不正常情況下也會(huì)拋出錯(cuò)誤,如果對(duì)錯(cuò)誤一無(wú)所知,便無(wú)從下手調(diào)試。綜合上述,了解錯(cuò)誤的處理機(jī)制是多么必要,以下是筆者歸納總結(jié),如有誤之處,歡迎指出。

錯(cuò)誤構(gòu)造函數(shù)

javascript規(guī)范中總共有8中錯(cuò)誤類(lèi)型構(gòu)造函數(shù)

Error -- 錯(cuò)誤對(duì)象

SyntaxError --解析過(guò)程語(yǔ)法錯(cuò)誤

TypeError -- 不屬于有效類(lèi)型

ReferenceError -- 無(wú)效引用

RangeError -- 數(shù)值超出有效范圍

URIError -- 解析URI編碼出錯(cuò)

EvalError -- 調(diào)用eval函數(shù)錯(cuò)誤

InternalError -- Javascript引擎內(nèi)部錯(cuò)誤的異常拋出, "遞歸太多"

其中兩種做個(gè)特殊說(shuō)明:

EvalError調(diào)用eval函數(shù)錯(cuò)誤,已經(jīng)棄用,為了向后兼容,低版本還可以使用。
InternalError 遞歸過(guò)深 拋出錯(cuò)誤,多數(shù)瀏覽器未實(shí)現(xiàn),屬于非標(biāo)準(zhǔn)方法,生產(chǎn)環(huán)境禁用

繼承關(guān)系

Error是錯(cuò)誤的基類(lèi),其他類(lèi)型都繼承Error這個(gè)類(lèi),可以使用ES6中提供的Object.getPrototypeOf()來(lái)判斷,一個(gè)類(lèi)是否繼承了另一個(gè)類(lèi)。

console.log(Object.getPrototypeOf(SyntaxError) === Error);    // true
console.log(Object.getPrototypeOf(TypeError) === Error);   // true
console.log(Object.getPrototypeOf(ReferenceError) === Error);   // true
console.log(Object.getPrototypeOf(RangeError) === Error);   // true
console.log(Object.getPrototypeOf(URIError) === Error);   // true
console.log(Object.getPrototypeOf(EvalError) === Error);   // true

來(lái)聊一聊每一種錯(cuò)誤類(lèi)型的使用和出錯(cuò)的場(chǎng)景。

Error

通過(guò)Error的構(gòu)造器可以創(chuàng)建一個(gè)錯(cuò)誤對(duì)象。當(dāng)運(yùn)行時(shí)錯(cuò)誤產(chǎn)生時(shí),Error的實(shí)例對(duì)象會(huì)被拋出。

語(yǔ)法:new Error([message])

參數(shù):

message 可選,錯(cuò)誤描述信息。

拋出錯(cuò)誤

使用throw語(yǔ)句來(lái)拋出異常

throw new Error("這里拋出的是錯(cuò)誤信息")

運(yùn)行后,會(huì)在控制臺(tái)打印輸出:

Uncaught Error: 這里拋出的是錯(cuò)誤信息

注意: 使用throw拋出異常后,之后的代碼不再執(zhí)行。

捕獲錯(cuò)誤

可以通過(guò)try{}catch(){}語(yǔ)句來(lái)捕獲到這個(gè)錯(cuò)誤

try{
    throw new Error("這里拋出的是錯(cuò)誤信息")
}catch(err){
    alert(err.name + " "+ err.message)
}

屬性說(shuō)明:
當(dāng)使用new Error創(chuàng)建錯(cuò)誤實(shí)例后,會(huì)有兩個(gè)屬性:

let e =  new Error("這里拋出的是錯(cuò)誤信息");

name屬性,為錯(cuò)誤的類(lèi)型,此時(shí)為Error
message屬性,為錯(cuò)誤的信息,此時(shí)為"這里拋出的是錯(cuò)誤信息"

SyntaxError

解析過(guò)程語(yǔ)法錯(cuò)誤,這種類(lèi)型拋出的錯(cuò)誤有很多,往往是書(shū)寫(xiě)時(shí)候造成的語(yǔ)法錯(cuò)誤,例如:

 let n = 11;   // Uncaught SyntaxError: Invalid or unexpected token
 let str = "hel"lo" // Uncaught SyntaxError: Unexpected identifier
 let 123Var = "hi" // Uncaught SyntaxError: Invalid or unexpected token

語(yǔ)法錯(cuò)誤有很多就不一一列舉了,當(dāng)在瀏覽器運(yùn)行時(shí),控制臺(tái)會(huì)拋錯(cuò),并且告知第幾行,所以調(diào)試器來(lái)比較方便。但要讀懂錯(cuò)誤的類(lèi)型為SyntaxError,以及后面的錯(cuò)誤信息,這樣方便改錯(cuò)。

TypeError

不屬于有效類(lèi)型。這種錯(cuò)誤就是在給的不是需要的類(lèi)型而導(dǎo)致無(wú)法操作,會(huì)拋出類(lèi)型錯(cuò)誤。

變量或參數(shù)不是預(yù)期類(lèi)型,

例如**new**運(yùn)算符后必須是函數(shù),而給定的不是函數(shù),則會(huì)拋出類(lèi)型錯(cuò)誤

let fn = "hello";
new fn;

拋出錯(cuò)誤:

Uncaught TypeError: fn is not a constructor

調(diào)用對(duì)象不存在的方法

let obj = {};
obj.fn()

拋出錯(cuò)誤:

Uncaught TypeError: obj.fn is not a function

當(dāng)然你也可以在封裝函數(shù)時(shí)候,強(qiáng)制傳入的參數(shù)為指定類(lèi)型,否則拋出類(lèi)型錯(cuò)誤。

function flatten(arr){
    if( !Array.isArray(arr) ){
        throw new TypeError("傳入?yún)?shù)不是數(shù)組")
    }    
}
flatten("test");

傳入的參數(shù)不為數(shù)組時(shí),拋出自定義的類(lèi)型錯(cuò)誤:

Uncaught TypeError: 傳入?yún)?shù)不是數(shù)組
ReferenceError

無(wú)效引用。

引用了一個(gè)不存在的變量

console.log(a);

拋出錯(cuò)誤

Uncaught ReferenceError: a is not defined

將變量賦值給一個(gè)無(wú)法被賦值的數(shù)據(jù)
這個(gè)錯(cuò)誤常常犯的地方實(shí)在調(diào)用一個(gè)方法后在if語(yǔ)句中做判斷,將比較運(yùn)算符==寫(xiě)成了賦值運(yùn)算符=,例如判斷一個(gè)字符串第一個(gè)字符是不是指定的字符:

let str = "hello";
if( str.charAt(0) = "h" ){
    console.log("第一個(gè)字符為h");
}

拋出錯(cuò)誤:

Uncaught ReferenceError: Invalid left-hand side in assignment

RangeError

數(shù)值超出有效范圍。在一些方法中,傳入的數(shù)值必須在一定的范圍內(nèi),否則會(huì)拋出超出范圍的錯(cuò)誤。

創(chuàng)建數(shù)組傳入的長(zhǎng)度小于了0

let arr = new Array(-1)

拋出錯(cuò)誤:

Uncaught RangeError: Invalid array length

repeat方法重復(fù)指定的字符串重復(fù)次數(shù)小于0

let str = "hello";
str.repeat(-1)

拋出錯(cuò)誤:

Uncaught RangeError: Invalid count value

URIError

處理URI編碼出錯(cuò)。函數(shù)參數(shù)不正確,主要是encodeURI()、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()和unescape()這六個(gè)函數(shù)。

例如:

decodeURIComponent("%");
decodeURI("%2")

拋出錯(cuò)誤:

Uncaught URIError: URI malformed

自定義錯(cuò)誤類(lèi)型

有時(shí)候希望自定義錯(cuò)誤類(lèi)型,需要自定義一個(gè)構(gòu)造函數(shù),然后讓原型繼承繼承Error.prototype即可。

function MyErrorType(message){
    this.message = message || "錯(cuò)誤";
    this.name = "MyErrorType";
    this.stack = (new Error()).stack;  // 錯(cuò)誤位置和調(diào)用棧
}

MyErrorType.prototype = Object.create(Error.prototype);
MyErrorType.prototype.constructor = MyErrorType;

throw new MyErrorType("自定義錯(cuò)誤類(lèi)型拋出錯(cuò)誤")
關(guān)于調(diào)用的錯(cuò)誤棧信息

提供的錯(cuò)誤的跟蹤功能,以什么樣的調(diào)用順序,在哪個(gè)文件的哪一行捕獲到這個(gè)錯(cuò)誤。
例如以下調(diào)用:

function trace() {
  try {
    throw new Error("myError");
  }
  catch(e) {
    console.log(e.stack);
  }
}
function b() {
  trace();
}
function a() {
  b(3, 4, "

", undefined, {});
}
a("first call, firstarg");

錯(cuò)誤信息為:

Error: myError
    at trace (:3:14)
    at b (:10:6)
    at a (:13:6)
    at :15:4

以上為拋錯(cuò)的構(gòu)造函數(shù)的總結(jié),如有誤之處歡迎扶正。
以上每一種錯(cuò)誤場(chǎng)景并沒(méi)有列出太多,如果你有新的錯(cuò)誤信息發(fā)現(xiàn),歡迎留言討論。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/88696.html

相關(guān)文章

  • JavaScript錯(cuò)誤異常探討

    摘要:提供一套錯(cuò)誤處理機(jī)制,錯(cuò)誤是干擾程序正常流程的非正常的事故。構(gòu)造函數(shù)是通用錯(cuò)誤類(lèi)型,除了類(lèi)型,還有等類(lèi)型。瀏覽器輸出其他錯(cuò)誤類(lèi)型構(gòu)造函數(shù)是繼承,實(shí)例是一致的。數(shù)值超出有效范圍數(shù)值超出有效范圍創(chuàng)建一個(gè)實(shí)例,表示錯(cuò)誤的原因無(wú)效引用。 同步發(fā)布于 https://github.com/xianshanna... 我的建議是不要隱藏錯(cuò)誤,勇敢地拋出來(lái)。沒(méi)有人會(huì)因?yàn)榇a出現(xiàn) bug 導(dǎo)致程序崩潰...

    LdhAndroid 評(píng)論0 收藏0
  • JavaScript 錯(cuò)誤處理與調(diào)試——“錯(cuò)誤處理”的注意要點(diǎn)

    摘要:使用函數(shù)發(fā)生異常時(shí)拋出。數(shù)值超出相應(yīng)范圍時(shí)拋出。拋出錯(cuò)誤與相配的還有一個(gè)操作符,用于拋出自定義錯(cuò)誤。錯(cuò)誤事件沒(méi)有通過(guò)處理的錯(cuò)誤都會(huì)觸發(fā)對(duì)象的事件。任何瀏覽器中,事件處理程序都不會(huì)創(chuàng)建對(duì)象,但它可以接受個(gè)參數(shù)錯(cuò)誤消息錯(cuò)誤所在的和行號(hào)。 try-catch語(yǔ)句 該語(yǔ)句最適合處理那些我們無(wú)法控制的錯(cuò)誤,在明明白白地知道自己的代碼會(huì)發(fā)生錯(cuò)誤時(shí),再使用該語(yǔ)句就不太合適了。 ECMA-262第3...

    draveness 評(píng)論0 收藏0
  • JavaScript 編程精解 中文第三版 八、Bug 和錯(cuò)誤

    摘要:幸運(yùn)的是,使用符號(hào)創(chuàng)建的構(gòu)造器,如果在不使用來(lái)調(diào)用,則始終會(huì)報(bào)錯(cuò),即使在非嚴(yán)格模式下也不會(huì)產(chǎn)生問(wèn)題。 來(lái)源:ApacheCN『JavaScript 編程精解 中文第三版』翻譯項(xiàng)目原文:Bugs and Errors 譯者:飛龍 協(xié)議:CC BY-NC-SA 4.0 自豪地采用谷歌翻譯 部分參考了《JavaScript 編程精解(第 2 版)》 調(diào)試的難度是開(kāi)始編寫(xiě)代碼的兩倍。 因此,如...

    wujl596 評(píng)論0 收藏0
  • JavaScript 中的錯(cuò)誤處理機(jī)制

    摘要:錯(cuò)誤處理在開(kāi)發(fā)和調(diào)試過(guò)程中都顯得尤為重要。跟全局函數(shù)有關(guān)的錯(cuò)誤,在之后已經(jīng)不再出現(xiàn)了內(nèi)部錯(cuò)誤。由引擎拋出的錯(cuò)誤范圍錯(cuò)誤。事件任何沒(méi)有的錯(cuò)誤都會(huì)觸發(fā)對(duì)象的事件。事件可以接收三個(gè)參數(shù)錯(cuò)誤消息錯(cuò)誤所在的和行號(hào)。 錯(cuò)誤處理在開(kāi)發(fā)和調(diào)試過(guò)程中都顯得尤為重要。有些沒(méi)有進(jìn)行錯(cuò)誤處理的應(yīng)用,直接就將瀏覽器的錯(cuò)誤展示給了用戶(hù),極大的降低了用戶(hù)體驗(yàn)。比如有些很 low 的網(wǎng)站,打開(kāi)某些頁(yè)面就直接彈出 ob...

    AbnerMing 評(píng)論0 收藏0
  • 錯(cuò)誤檢測(cè)(1)------try-catch語(yǔ)句 From 《高程3》

    摘要:類(lèi)型的錯(cuò)誤會(huì)在數(shù)值超出相應(yīng)范圍時(shí)觸發(fā)。最常發(fā)生類(lèi)型錯(cuò)誤的情況,就是傳遞給函數(shù)的參數(shù)事先未經(jīng)檢查,結(jié)果傳入類(lèi)型與預(yù)期類(lèi)型不相符。捕獲錯(cuò)誤的目的在于避免瀏覽器以默認(rèn)方式處理它們而拋出錯(cuò)誤的目的在于提供錯(cuò)誤發(fā)生具體原因的消息。 0 前言 目前讀到了《高程3》的錯(cuò)誤檢測(cè)部分,現(xiàn)在先挖一個(gè)坑,關(guān)于錯(cuò)誤檢測(cè)應(yīng)該寫(xiě)三篇總結(jié):firebug檢測(cè)錯(cuò)誤和輸出信息;try-catch錯(cuò)誤捕獲;常見(jiàn)錯(cuò)誤種類(lèi)。...

    UnixAgain 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<