JavaScript容錯例外處理
更新時間:2008年06月08日 20:03:45 作者:
程序開發(fā)中,編程人員經(jīng)常要面對的是如何編寫代碼來響應錯誤事件的發(fā)生,即例外處理(exception handlers)。
六、定制例外信息
上述的六種Error類型基本上覆蓋了腳本程序運行時所可能發(fā)生的錯誤。除了這些類型以外,我們還可以使用Error構(gòu)造器來自定義例外類型,其語法如下:
myError = new Error(msg)
其中msg參數(shù)表示所定義的新例外的message屬性值。同時,我們還可以創(chuàng)建新的對象類型以作為Error的子類型:
function MyError(msg) {
this.name = "MyError"
this.message = msg
}
MyError.prototype = new Error;
然后,我們就可以創(chuàng)建自定義錯誤子類的實例:
myError = new MyError("My error message")
七、觸發(fā)例外
創(chuàng)建一個Error對象后,就可以使用throw語句來觸發(fā)相應的例外。Throw的語法如下:
throw errObj
errObj必須是一個Error對象或者Error的子類型。在try塊代碼中觸發(fā)一個例外后,控制將直接轉(zhuǎn)入catch塊。
下面的代碼中,在try塊中觸發(fā)了一個例外,設(shè)置例外信息為“oops”,然后控制轉(zhuǎn)移到catch塊:
var s
try {
s = "one "
throw new Error("oops")
s += "two"
} catch(err) {
s += err.message
}
s += " three"
alert(s)
運行后出現(xiàn)如下的提示框:
編寫代碼來觸發(fā)例外的優(yōu)點很多,比如有利于自定義錯誤類型,快速轉(zhuǎn)入catch塊執(zhí)行,以及下面要介紹的在嵌套例外中將錯誤傳遞到外層。
八、嵌套例外處理
JavaScript支持多層次的嵌套例外處理。一般情況下,我們可以在內(nèi)部例外處理的catch代碼塊中捕捉并處理錯誤,然后再次觸發(fā)例外,這樣就可進一步在外部例外處理的catch代碼塊中做更加深入的處理。下面來看看一個嵌套例外處理的例子:
var inner;
var outer;
try {
document.writeln("Beginning outer try block, no exceptions yet");
try{
document.writeln("Beginning inner try block, no exceptions yet");
// 生成一個引用錯誤
document.writeln(undefinedVariable)
document.writeln("Finished inner try block with no exceptions");
} catch(inner) {
// 內(nèi)部例外處理
document.writeln("Exception caught, beginning inner catch block");
document.writeln("Error type: " + inner.name);
document.writeln("Error message: " + inner.message);
throw inner;
document.writeln("No exceptions thrown in inner catch block");
} finally {
document.writeln("Executing inner finally block");
}
document.writeln("Finished outer try block with no exceptions");
} catch(outer) {
// 外部例外處理
document.writeln("Exception caught, beginning outer catch block");
document.writeln("Error type: " + outer.name);
document.writeln("Error message: " + outer.message);
} finally {
document.writeln("Executing outer finally block");
}
執(zhí)行后的輸出結(jié)果如下:
Beginning outer try block, no exceptions yet
Beginning inner try block, no exceptions yet
Exception caught, beginning inner catch block
Error type: ReferenceError
Error message: undefinedVariable is not defined
Executing inner finally block
Exception caught, beginning outer catch block
Error type: ReferenceError
Error message: undefinedVariable is not defined
Executing outer finally block
嵌套例外處理的好處在于使我們能夠很好地分階段處理錯誤,內(nèi)部例外處理可以負責解決由錯誤引發(fā)的腳本代碼問題,外部例外處理則用于負責提供給用戶的反饋信息或者對例外信息進行日志記錄。
九、結(jié)語
本文詳細討論了JavaScript語言的一個很重要的特征“例外處理”,Web開發(fā)人員應該很好地掌握它并在實際應用中靈活處理,從而使包含腳本代碼的HTML頁面真正地不出例外、善解人意。
相關(guān)文章
JavaScript實現(xiàn)拖拽元素對齊到網(wǎng)格(每次移動固定距離)
最近在做一個拖拽元素的附加功能,就是對齊到網(wǎng)格,實際上就是確定好元素的初始位置,然后拖拽元素時,每次移動固定的距離。讓元素都可以在網(wǎng)格內(nèi)對齊2016-11-11JavaScript的基礎(chǔ)語法和數(shù)據(jù)類型詳解
這篇文章主要介紹了JavaScript的基礎(chǔ)語法和數(shù)據(jù)類型,保姆級的詳細教程,萬字長文詳細的列出了JavaScript的各種語法,建議收藏系列,希望可以有所幫助2021-09-09js window.onload 加載多個函數(shù)和追加函數(shù)詳解
本篇文章主要是對js window.onload 加載多個函數(shù)和追加函數(shù)進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01