一、错误分类
1、语法错误:也称解析错误,发生在传统语言的编译时,在JavaScript中发生在解释时。这些错误是由代码中的意外字符直接引起的,然后就不能直接编译/解释。发生语法错误时,就不能继续执行代码。在JavaScript中,只有在同一个线程中的代码会受语法错误的影响。在其他线程中的代码和其他外部引用的文件中的代码,如果不依赖于包含错误的代码,则可以继续执行。
2、运行时错误:也称为异常(exception,在编译期/解释器后)。此时,问题并不出在代码的语法上,而是,尝试完成的一个操作,在某些情况下是非法的。异常只影响发生的线程,其他JavaScript线程即可继续正常的执行。
二、错误处理
JavaScript提供了两种处理错误的方式:BOM中的onerror事件处理函数方式和ECMAScript中的try...catch方式。
1、onerror事件处理函数
它是第一个用来协助JavaScript处理错误的机制。页面上出现异常时,error事件便在window对象上触发。例如:
复制代码 代码如下:
<html>
<head>
<title>onerror Example</title>
<script type="text/javascript">
window.onerror = function() {
alert("发生错误!");
}
</script>
</head>
<body>
</body>
</html>
在上述代码中,在页面载入时尝试调用不存在的函数,此时会引发一个异常。弹出“发生错误”的错误信息。但是,浏览器的错误信息也显示出来了,如何在浏览器上隐藏它呢,只需onerror方法返回一个true即可。
复制代码 代码如下:
<script type="text/javascript">
window.onerror = function() {
alert(“发生错误!”);
return true;
}
</script>
1.1 取出错误信息
onerror处理函数提供了三种信息来确定错误确切的性质:
i) 错误信息——对于给定错误,浏览器会显示同样的信息
ii) URL——在哪个文件中发生了错误
iii) 行号——给定URL中发生错误的行号。
复制代码 代码如下:
window.onerror = function(sMessage, sUrl, iLine) {
alert("发生错误!\n" + sMessage + "\nURL:" + sUrl + "\nLine Number:" + iLine);
return true;
}
1.2 图像载入错误
window对象并非唯一支持onerror事件处理函数的对象,它对图像对象也提供支持。当一个图像由于文件不存在等原因未能成功载入时,error事件便在这个图像上触发。例如:
复制代码 代码如下:
<img src="https://www.jb51.net/noexist.gif" onerror="alert('载入图片时发生错误')"/>
上例直接在HTML中分配onerror事件处理函数。因为noexist.gif不存在,所以会弹出警告框提示用户。当然也可以通过脚本来分配事件处理函数,在设置图像的src特性前,必须等待页面完全载入,例如:
复制代码 代码如下:
<html>
<head>
<title>Image错误测试</title>
<script type="text/javascript">
function handleLoad() {
document.images[0].onerror = function() {
alert("载入图片时发生错误!");
};
document.images[0].src = "amigo.jpg";
}
</script>
</head>
<body>
<img/>
<body>
</html>
注意:与window对象的onerror事件处理函数不同,image的onerror事件没有任何关于额外信息的参数。
1.3处理语法错误
onerror事件处理函数不仅可以处理异常,它还能处理语法错误,也只有它才能处理。
首先,事件处理函数必须是页面中第一个出现的代码,因为如果语法错误出现在设置事件处理函数之前出现,事件处理函数就没有用了。记住,语法错误会完全停止代码的执行。例如:
复制代码 代码如下:
<html>
<head>
<title>onError Example</title>
<script type="text/javascript">
alert("Syntax error.";
window.onerror = function (sMessage, sUrl, iLine){
alert("An error occurrred:\n" + sMessage + "\nURL:" + sUrl + "\nLine Number:" + iLine );
return true;
}
</script>
</head>
<body>
</body>
</html>
因为突出显示的那一行代码(里面有错误语法)在分配onerror事件处理函数之前就出现了,所以浏览器直接报告这个错误。在错误之后的代码就不再被解释(因为这个线程已经退出了),所以 load 事件解发时调用 nonExistentFunction() ,浏览器也会报这个错误。书中说如果重写这个页面,将 onerror 事件处理函数的分配放在语法错误之前,那么会出现两个警告框:一个显示语法错误,另一个显示异常。但我测试的结果还是一样的报两个错误,并不显示onerror事件中的信息。
使用onerror事件处理函数的主要的问题是,它是BOM的一部分,所以,没有任何标准能控制它的行为。因此,不同的浏览器使用这个事件处理错误的方式有明显的不同,eg,在IE中发生error事件时,正常的代码会继续执行,所有的变量和数据都保留下来,并可通过onerror事件处理函数访问。在Mozilla中,正常的代码执行都会结束,同时所有的错误发生之前的变量和数据都被销毁。
2、try...catch方式
ECMPScript第三版,引入了try…catch语句。基本语法如下:
复制代码 代码如下:
try{
//code
[break;]
} catch ([exception]) {
//code
[break;]
} [finally{
//code
}]
例如:
复制代码 代码如下: