JavaScript錯(cuò)誤處理
一.錯(cuò)誤分類
1. 語法錯(cuò)誤
也稱為解析錯(cuò)誤,發(fā)生在傳統(tǒng)編程語言的編譯時(shí),在JavaScript中發(fā)生在解釋時(shí),這些錯(cuò)誤是由代碼中的意外字符直接引起的,然后就不能直接編譯/解釋,eg,在一行代碼因缺少右括號,產(chǎn)生了語法錯(cuò)誤。發(fā)生語法錯(cuò)誤時(shí),就不能繼續(xù)執(zhí)行代碼。在JavaScript中,只有在同一個(gè)線程中的代碼會(huì)受語法錯(cuò)誤的影響。在其他線程中的代碼和其他外部引用的文件中的代碼,如果不依賴于包含錯(cuò)誤的代碼,則可以繼續(xù)執(zhí)行。
2. 運(yùn)行時(shí)錯(cuò)誤
也稱為異常(exception,在編譯期/解釋器后)。此時(shí),問題并不出在代碼的語法上,而是,嘗試完成的一個(gè)操作,在某些情況下是非法的。eg.
window.openMyFile();
因不存在openMyFile()方法,瀏覽器會(huì)返回一個(gè)異常。異常只影響發(fā)生的線程,其他JavaScript線程即可繼續(xù)正常的執(zhí)行。
二.處理錯(cuò)誤
1. onerror事件處理函數(shù)
它是第一個(gè)用來協(xié)助JavaScript處理錯(cuò)誤的機(jī)制。頁面上出現(xiàn)異常時(shí),error事件便在window對象上觸發(fā)。Eg.
<html>
<head>
<title>onerror例子</title>
<script type="text/javascript">
window.onerror = function() {
alert("發(fā)生錯(cuò)誤!");
}
</script>
</head>
<body onload="fuction1()">
</body>
</html>
在上述代碼中,在頁面載入時(shí)嘗試調(diào)用不存在的函數(shù),此時(shí)會(huì)引發(fā)一個(gè)異常。彈出“發(fā)生錯(cuò)誤”的錯(cuò)誤信息。但是,瀏覽器的錯(cuò)誤信息也顯示出來了,如何在瀏覽器上隱藏它呢,只需onerror方法返回一個(gè)true即可。
<script type="text/javascript">
window.onerror = function() {
alert(“發(fā)生錯(cuò)誤!”);
return true;
}
</script>
1) 取出錯(cuò)誤信息
onerror處理函數(shù)提供了三種信息來確定錯(cuò)誤確切的性質(zhì):
i)錯(cuò)誤信息——對于給定錯(cuò)誤,瀏覽器會(huì)顯示同樣的信息;
ii)URL——在哪個(gè)文件中發(fā)生了錯(cuò)誤;
行號——給定URL中發(fā)生錯(cuò)誤的行號。
訪問方法見如下例子:
<script type="text/javascript">
window.onerror = function(sMessage, sUrl, sLine) {
alert("發(fā)生錯(cuò)誤!\n" + sMessage + "\nURL:" + sUrl + "\nLine Number:" + sLine);
return true;
}
</script>
2) 圖像載入錯(cuò)誤
window對象并非唯一支持onerror事件處理函數(shù)的對象,它對圖像對象也提供支持。當(dāng)一個(gè)圖像由于文件不存在等原因未能成功載入時(shí),error事件便在這個(gè)圖像上觸發(fā)。讓我們來看一個(gè)例子:
<img src=”amigo.jpg” onerror=”alert(‘載入圖片時(shí)發(fā)生錯(cuò)誤')”/>
上例直接在HTML中分配onerror事件處理函數(shù)。當(dāng)然也可以通過腳本來分配事件處理函數(shù),在設(shè)置圖像的src特性前,必須等待頁面完全載入,代碼如下:
<html>
<head>
<title>Image錯(cuò)誤測試</title>
<script type="text/javascript">
function handleLoad() {
document.images[0].onerror = function() {
alert("載入圖片時(shí)發(fā)生錯(cuò)誤!");
};
document.images[0].src = "amigo.jpg";
}
</script>
</head>
<body onload="handleLoad()">
<img/>
<body>
</html>
注意:與window對象的onerror事件處理函數(shù)不同,image的onerror事件任何的額外信息的參數(shù)。
3) 處理語法錯(cuò)誤
onerror還能處理語法錯(cuò)誤。但有一點(diǎn)必須注意,事件處理函數(shù)必須是頁面中第一個(gè)出現(xiàn)的代碼,因?yàn)槿绻Z法錯(cuò)誤出現(xiàn)在設(shè)置事件處理函數(shù)之前出現(xiàn),事件處理函數(shù)就沒有用了。
注意:語法錯(cuò)誤會(huì)完全停止代碼的執(zhí)行。
說明:使用onerror事件處理函數(shù)的主要的問題是,它是BOM的一部分,所以,沒有任何標(biāo)準(zhǔn)能控制它的行為。因此,不同的瀏覽器使用這個(gè)事件處理錯(cuò)誤的方式有明顯的不同,eg,在IE中發(fā)生error事件時(shí),正常的代碼會(huì)繼續(xù)執(zhí)行,所有的變量和數(shù)據(jù)都保留下來,并可通過onerror事件處理函數(shù)訪問。在Mozilla中,正常的代碼執(zhí)行都會(huì)結(jié)束,同時(shí)所有的錯(cuò)誤發(fā)生之前的變量和數(shù)據(jù)都被銷毀。
2. try…catch語句
ECMPScript第三版,引入了try…catch語句。Eg.
try {
window.openFile1();
alert("成功調(diào)用openFile1方法");
} catch (exception) {
alert("發(fā)生異常!");
} finally {
alert("try..catch測試結(jié)束!");
}
與Java不同,ECMAScript標(biāo)準(zhǔn)在try…catch語句中只能有一個(gè)catch語句,因?yàn)镴avaScript是弱類型的語言,沒辦法指明catch子句中異常的特定類型。不管錯(cuò)誤是什么類型,都由同一個(gè)catch語句處理。但Mozilla對其進(jìn)行了擴(kuò)展,可加多個(gè)catch語句,不推薦這樣使用。
finally用于包含無論是否有異常發(fā)生都要執(zhí)行的代碼,這對關(guān)閉打開的鏈接和釋放資源很有用。
1) 嵌套try…catch語句
用來處理catch子句中的錯(cuò)誤問題,讓我們來看一個(gè)例子,代碼如下:
try {
eval("a ++ b");
} catch(oException) {
alert("發(fā)生錯(cuò)誤!");
try {
var aError = new Array(1000000000000000000000000000000000000000);
} catch(exception) {
alert("在catch子句中發(fā)生錯(cuò)誤!");
}
} finally{
alert("已完成")
}
2) Error對象
發(fā)生錯(cuò)誤時(shí),JavaScript有個(gè)Error基類用于拋出。它有兩個(gè)特性:
i)name——表示錯(cuò)誤類型的字符串
ii)message——實(shí)際的錯(cuò)誤信息。
Error對象的name對應(yīng)于它的類,可以是如下值之一:
EvalError:錯(cuò)誤發(fā)生在eval()函數(shù)中;
RangeError:數(shù)字值超出JavaScript可表示的范圍;
ReferenceError:使用了非法的引用;
SyntaxError:在eval()函數(shù)調(diào)用中發(fā)生了語法錯(cuò)誤,其他的愈發(fā)錯(cuò)誤由瀏覽器報(bào)告,無法通過try…catch處理;
TypeError:變量的類型不是預(yù)期所需的;
URIError:在encodeURI或decodeURI函數(shù)發(fā)生了錯(cuò)誤。
3) 判斷錯(cuò)誤類型
可采取如下兩種方法來判斷錯(cuò)誤類型,第一種根據(jù)異常的name屬性判斷,如下:
try {
eval("a ++ b");
} catch(oException) {
if (oException.name = "SyntaxError") {
alert("發(fā)生SyntaxError!");
} else {
alert("發(fā)生其他錯(cuò)誤!");
}
}
第二中采用instanceof操作符,代碼如下:
try {
eval("a ++ b");
} catch(oException) {
if (oException instanceof SyntaxError) {
alert("發(fā)生SyntaxError!");
} else {
alert("發(fā)生其他錯(cuò)誤!");
}
}
4) 拋出異常的throw語句
在ECMAScript第三版引入,用于有目的的拋出異常,拋出的錯(cuò)誤對象可為字符串、數(shù)字、布爾值或?qū)嶋H的對象,也可以拋出Error對象(其構(gòu)造函數(shù)只有一個(gè)函數(shù),即錯(cuò)誤信息)。eg1. throw new Error(“錯(cuò)誤產(chǎn)生!”);
eg2.
function addTwoNumber(a, b) {
if (arguments.length < 2) {
throw new Error("需要傳入兩個(gè)數(shù)字!");
}
}
try {
result = addTwoNumber(90);
} catch(oException) {
if (oException instanceof SyntaxError) {
alert("SyntaxError:" + oException.message);
} else if (oException instanceof Error){
alert(oException.message);
}
}
以上就是本文所述的全部內(nèi)容了,希望小伙伴們能夠喜歡。
相關(guān)文章
JS localStorage存儲(chǔ)對象,sessionStorage存儲(chǔ)數(shù)組對象操作示例
這篇文章主要介紹了JS localStorage存儲(chǔ)對象,sessionStorage存儲(chǔ)數(shù)組對象操作,結(jié)合實(shí)例形式詳細(xì)分析了JS使用localStorage存儲(chǔ)對象以及sessionStorage存儲(chǔ)數(shù)組對象相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2020-02-02如何在?xHTML?中驗(yàn)證?noscript+meta?refresh?標(biāo)簽
這篇文章主要介紹了如何在?xHTML?中驗(yàn)證?noscript+meta?refresh?標(biāo)簽,需要的朋友可以參考下2023-03-03詳解JavaScript設(shè)計(jì)模式中的享元模式
享元模式是一種用于性能優(yōu)化的模式。享元模式的核心是運(yùn)用共享技術(shù)來有效支持大量細(xì)粒度的對象.如果系統(tǒng)中創(chuàng)建了大量類似的對象而導(dǎo)致內(nèi)存占用過高,本文通過介紹書中文件上傳的優(yōu)化案例來說明享元模式的使用方式和作用,需要的朋友可以參考下2023-06-06JS和jQuery使用submit方法無法提交表單的原因分析及解決辦法
這篇文章主要介紹了JS和jQuery使用submit方法無法提交表單的原因分析及解決辦法的相關(guān)資料,需要的朋友可以參考下2016-05-05JavaScript學(xué)習(xí)筆記之基于定時(shí)器實(shí)現(xiàn)圖片無縫滾動(dòng)功能詳解
這篇文章主要介紹了JavaScript學(xué)習(xí)筆記之基于定時(shí)器實(shí)現(xiàn)圖片無縫滾動(dòng)功能,結(jié)合實(shí)例形式分析了javascript定時(shí)器與頁面元素屬性動(dòng)態(tài)設(shè)置等相關(guān)操作技巧,需要的朋友可以參考下2019-01-01