荒谬所在代码行

onerror语法使用

onerror 默认有三个入参:

•msg: 错误信息•url:错误所在文件•line:
错误所在代码行,整型window.onerror = function{ // some code }; 对于

形式的,可以通过arguments[0]、arguments[1]、arguments[2]依次获取参数。

js中我们最常用的就是js容错

window.onerror=function(){return true;}

基本特性可以通过设置returnValue=true,或直接return
true来阻止浏览器显示错误信息。但不会阻止script
debuggers弹出的调试框。只有运行错误才会触发onerror,语法错误不会触发。

以下三种方式可以引发onerror:

•运行时错误,例如无效的对象引用或安全限制•下载错误,如图片•在IE9中,获取多媒体数据失败也会引发

上面示例的方法很值得借鉴。
在捕获js错误时,我们通常使用try{}catch{}的方式,然后通过e.errorMessage等方式获取错误信息然后报告错误。但对于onerror事件可能很少问津,我们是否思考过如何报告错误所在的行号?如果想过这个是否也被这个问题所困扰过,是否认为在js里不可能捕获错误的行号呢?其实本人就遇到上述的几个问题,今日读某人写的一段js代码顿然发现了onerror事件,要说onerror这个时间也是n久以前就知道了,但对于其所带有的三个参数和其特殊性质却一直没有去了解过。经过自己的研究测试,对onerror事件有了一些新的认识和了解。在页面没有错误时,window.onerror事件是不存在的,也就是null(废话!没出错如果onerror出现还正常吗?)我们一般通过函数名传递的方式将要执行的操作函数传递给onerror事件,如window.onerror=reportError;window.onerror=function},但我们可能不知道该事件触发时还带有三个默认的参数,他们分别是错误信息,错误页面的url和错误行号。要知道这个可是事件,就如onclick和onmouseover等事件一样,但它是有参数。我们可以这样测试。

 window.onerror=testError; function testError(){ arglen=arguments.length; var errorMsg="参数个数:"+arglen+"个"; for{ errorMsg+="/n参数"++":"+arguments[i]; } alert; window.onerror=null; return true; } function test  

首先将testError方法绑定给onerror事件,然后在test方法里触发一个错误,在IE中执行时我们发现如下提示:—————————
Microsoft Internet Explorer ————————— 参数个数:3个
参数1:’error’ 未定义 参数2:file://E:/yanwei/test/testError.html
参数3:14 ————————— 确定 —————————
可以发现,当出错时函数testError捕获到了三个参数。通过将函数绑定到onerror事件就可以在页面出错时捕获以上三个参数。
在测试中还发现以下一些问题:1、通过在函数末尾加上return
true,可以在函数出错时不会弹出系统的错误信息。2、如果页面出现多次错误,只捕获第一次错误并进行处理然后终止后面程序的执行。
3、onerror事件并不能捕获所有的错误,只能捕获函数外或函数内错误,如
adasdf; function test(){ aaaa; } 可以捕获到adasdf未定义的错误 function
test(){ aaaa; } 可以捕获到aaaa未定义的错误,而对于functiona testdd{}
的错误却不能捕获而会直接弹出系统错误信息。4、onerror在IE和FF等浏览器执行方式是一样的,而且都包含这三个参数。

相关文章