二十一、js異常
1.錯誤關鍵詞
try 語句使您能夠測試代碼塊中的錯誤。
catch 語句允許您處理錯誤。
throw 語句允許您創建自定義錯誤。
finally 使您能夠執行代碼,在 try 和 catch 之後,無論結果如何。
<p id="demo"></p>
<script>
try {adddlert("歡迎訪問!");}
catch(err) { document.getElementById("demo").innerHTML = err.message;}
</script>
JavaScript 將 adddlert 捕獲爲一個錯誤,然後執行代碼來處理該錯誤。
2. try 和 catch
try 語句允許您定義一個代碼塊,以便在執行時檢測錯誤。
catch 語句允許你定義一個要執行的代碼塊,如果 try 代碼塊中發生錯誤。
JavaScript 語句 try 和 catch 成對出現:
try {供測試的代碼塊}
catch(err) {處理錯誤的代碼塊}
3.拋出錯誤
當發生錯誤時,JavaScript 將拋出異常(拋出錯誤)。
avaScript 實際上會創建帶有兩個屬性的 Error 對象:name 和 message。
4.throw
throw 語句允許您創建自定義錯誤。
從技術上講您能夠拋出異常(拋出錯誤)。
5.finally
finally 語句允許您在 try 和 catch 之後執行代碼,無論結果:
try {供測試的代碼塊}
catch(err) {處理錯誤的代碼塊}
finally {無論 try / catch 結果如何都執行的代碼塊}
6.Error 對象
JavaScript 擁有當錯誤發生時提供錯誤信息的內置 error 對象。
(1)Eval 錯誤:EvalError 指示 eval() 函數中的錯誤。(更新版本的 JavaScript 不會拋出任何 EvalError。請使用 SyntaxError 代替。)
(2)範圍錯誤:RangeError 會在您使用了合法值的範圍之外的數字時拋出。
var num = 1;
try {
num.toPrecision(500); // 數無法擁有 500 個有效數
}
catch(err) {
document.getElementById("demo").innerHTML = err.name;// RangeError
document.getElementById("demo2").innerHTML = err.message;
// toPrecision() argument must be between 1 and 100
}
(3)引用錯誤:假如您使用(引用)了尚未聲明的變量,則 ReferenceError 會被拋出
var x;
try {x = y + 1; // y 無法被引用(使用)}
catch(err) {
document.getElementById("demo").innerHTML = err.name;// ReferenceError
document.getElementById("demo2").innerHTML = err.message;// y is not defined
}
(4)語法錯誤:假如您計算帶語法錯誤的代碼,會 SyntaxError 被拋出
eval() 函數可計算某個字符串,並執行其中的的 JavaScript 代碼。
try {eval("alert('Hello)"); // 缺少 ' 會產生錯誤}
catch(err) {
document.getElementById("demo").innerHTML = err.name;// SyntaxError
document.getElementById("demo2").innerHTML = err.message;// Invalid or unexpected token
}
(5)類型錯誤:假如您使用的值不在期望值的範圍之內,則 TypeError 被拋出
var num = 1;
try {
num.toUpperCase(); // 您無法將數字轉換爲大寫
}
catch(err) {
document.getElementById("demo").innerHTML = err.name;// TypeError
document.getElementById("demo2").innerHTML = err.message;
// num.toUpperCase is not a function
}
(6)URI 錯誤
假如您在 URI 函數中使用非法字符,則 URIError 被拋出
try {
decodeURI("%%%"); // 您無法對這些百分號進行 URI 編碼
}
catch(err) {
document.getElementById("demo").innerHTML = err.name;// URIError
document.getElementById("demo2").innerHTML = err.message;
// undefined
}