JavaScript - 捕獲錯(cuò)誤
當(dāng)我們?cè)诰W(wǎng)上沖浪時(shí),總會(huì)看到帶有 runtime 錯(cuò)誤的 Javascript 警告框,同時(shí)會(huì)詢問我們“是否進(jìn)行 debug?”。像這樣的錯(cuò)誤信息或許對(duì)開發(fā)人員有用,對(duì)用戶則未必。當(dāng)錯(cuò)誤發(fā)生時(shí),他們往往會(huì)選擇離開這個(gè)站點(diǎn)。
有兩種在網(wǎng)頁中捕獲錯(cuò)誤的方法:
使用try...catch語句。(在 IE5+、Mozilla 1.0、和 Netscape 6 中可用)
使用onerror事件。這是用于捕獲錯(cuò)誤的老式方法。(Netscape 3 以后的版本可用)
注意:chrome、opera 和 safari 瀏覽器不支持 onerror 事件。
在JavaScript可以使用try...catch來進(jìn)行異常處理。例如:
語法:

目前我們可能得到的系統(tǒng)異常主要包含以下6種:
1、EvalError: raised when an error occurs executing code in eval()
2、RangeError: raised when a numeric variable or parameter is outside of its valid range
3、ReferenceError: raised when de-referencing an invalid reference
4、SyntaxError: raised when a syntax error occurs while parsing code in eval()
5、TypeError: raised when a variable or parameter is not a valid type
6、URIError: raised when encodeURI() or decodeURI() are passed invalid parameters
上面的六種異常對(duì)象都繼承自Error對(duì)象。他們都支持以下兩種構(gòu)造方法:
new Error();
new Error("異常信息");
手工拋出異常的方法如下:
try {
throw new Error("Whoops!");
} catch (e) {
alert(e.name + ": " + e.message);
}
如要判斷異常信息的類型,可在catch中進(jìn)行判斷:
try {
foo.bar();
} catch (e) {
if (e instanceof EvalError) {
alert(e.name + ":" + e.message);
}
else if (e instanceof RangeError) {
alert(e.name + ": " + e.message);
}
//........
}
Error具有下面一些主要屬性:
description: 錯(cuò)誤描述 (僅IE可用).
fileName: 出錯(cuò)的文件名 (僅Mozilla可用).
lineNumber: 出錯(cuò)的行數(shù) (僅Mozilla可用).
message: 錯(cuò)誤信息 (在IE下同description)
name: 錯(cuò)誤類型.
number: 錯(cuò)誤代碼 (僅IE可用).
stack: 像Java中的Stack Trace一樣的錯(cuò)誤堆棧信息 (僅Mozilla可用).
因此為了更好的了解錯(cuò)誤信息我們可以將catch部分改為如下形式:
try {
foo.bar();
} catch (e) {
if (browserType != BROWSER_IE) {
alert("name: " + e.name +
"message: " + e.message +
"lineNumber: " + e.lineNumber +
"fileName: " + e.fileName +
"stack: " + e.stack);
}
else {
alert("name: " + e.name +
"errorNumber: " + (e.number & 0xFFFF ) +
"message: " + e.message");
}
}
JavaScript中的throw命令事實(shí)上可以拋出任何對(duì)象,并且我們可以在catch接受到此對(duì)象。例如:
try {
throw new Date(); // 拋出當(dāng)前時(shí)間對(duì)象
} catch (e) {
alert(e.toLocaleString()); // 使用本地格式顯示當(dāng)前時(shí)間
}
實(shí)例1:


實(shí)例2:
