javascript window.onerror事件学习新收获
2007-11-02 22:25
288 查看
在捕获js错误时,我们通常使用try{}catch(e){}的方式,然后通过e.errorMessage等方式获取错误信息然后报告错误。但对于onerror事件可能很少问津,我们是否思考过如何报告错误所在的行号?如果想过这个是否也被这个问题所困扰过,是否认为在js里不可能捕获错误的行号呢?其实本人就遇到上述的几个问题,今日读某人写的一段js代码顿然发现了onerror事件,要说onerror这个时间也是n久以前就知道了,但对于其所带有的三个参数和其特殊性质却一直没有去了解过。经过自己的研究测试,对onerror事件有了一些新的认识和了解。在页面没有错误时,window.onerror事件是不存在的,也就是null(废话!没出错如果onerror出现还正常吗?)我们一般通过函数名传递的方式(引用的方式)将要执行的操作函数传递给onerror事件,如window.onerror=reportError;window.onerror=function(){alert('error')},但我们可能不知道该事件触发时还带有三个默认的参数,他们分别是错误信息,错误页面的url和错误行号。要知道这个可是事件,就如onclick和onmouseover等事件一样,但它是有参数。我们可以这样测试。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
首先将testError方法绑定给onerror事件,然后在test方法里触发一个错误,在IE中执行时我们发现如下提示:
---------------------------
Microsoft Internet Explorer
---------------------------
参数个数:3个
参数1:'error' 未定义
参数2:file://E:\yanwei\test\testError.html
参数3:14
---------------------------
确定
---------------------------
可以发现,当出错时函数testError捕获到了三个参数。通过将函数绑定到onerror事件就可以在页面出错时捕获以上三个参数。
在测试中还发现以下一些问题:
1、通过在函数末尾加上return true,可以在函数出错时不会弹出系统的错误信息(IE)。
2、如果页面出现多次错误,只捕获第一次错误并进行处理然后终止后面程序的执行。
3、onerror事件并不能捕获所有的错误,只能捕获函数外或函数内错误(??这个是什么意思,可不是开玩笑呢),如 adasdf;
function test(){
aaaa;
}
可以捕获到adasdf未定义的错误
function test(){
aaaa;
}
可以捕获到aaaa未定义的错误,而对于functiona test(){}或function test()dd{} 的错误却不能捕获而会直接弹出系统错误信息。
4、onerror在IE和FF等浏览器执行方式是一样的,而且都包含这三个参数。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
首先将testError方法绑定给onerror事件,然后在test方法里触发一个错误,在IE中执行时我们发现如下提示:
---------------------------
Microsoft Internet Explorer
---------------------------
参数个数:3个
参数1:'error' 未定义
参数2:file://E:\yanwei\test\testError.html
参数3:14
---------------------------
确定
---------------------------
可以发现,当出错时函数testError捕获到了三个参数。通过将函数绑定到onerror事件就可以在页面出错时捕获以上三个参数。
在测试中还发现以下一些问题:
1、通过在函数末尾加上return true,可以在函数出错时不会弹出系统的错误信息(IE)。
2、如果页面出现多次错误,只捕获第一次错误并进行处理然后终止后面程序的执行。
3、onerror事件并不能捕获所有的错误,只能捕获函数外或函数内错误(??这个是什么意思,可不是开玩笑呢),如 adasdf;
function test(){
aaaa;
}
可以捕获到adasdf未定义的错误
function test(){
aaaa;
}
可以捕获到aaaa未定义的错误,而对于functiona test(){}或function test()dd{} 的错误却不能捕获而会直接弹出系统错误信息。
4、onerror在IE和FF等浏览器执行方式是一样的,而且都包含这三个参数。
您可能感兴趣的文章:
- JavaScript探测CSS动画是否已经完成的方法
- javascript字典探测用户名工具
- 用javascript实现给图片加链接
- js实现点击链接后延迟3秒再跳转的方法
- JS实现点击链接取消跳转效果的方法
- JS获得URL超链接的参数值实例代码
- JS对img标签进行优化使用onerror显示默认图像
- js注意img图片的onerror事件的分析
- JS使用onerror捕获异常示例
- JavaScript通过使用onerror设置默认图像显示代替alt
- 用window.onerror捕获并上报Js错误的方法
- JavaScript中的onerror事件概述及使用
- JS实现探测网站链接的方法【测试可用】
相关文章推荐
- javascript window.onerror事件学习新收获
- window.onerror事件学习新收获
- window.onerror 事件学习新收获
- javascript window.onerror事件
- 韩顺平 javascript教学视频_学习笔记27_dom对象(window对象3.history.location.navigator.screen.event)_js事件驱动编程
- window.onerror事件学习新收获
- Javascript学习--------认识window窗口对象
- Javascript学习(二)——事件
- 有关window.onerror事件的监听及用法
- 轻松学习JavaScript二十八:DOM编程学习之事件处理函数
- javascript中的事件学习总结
- JavaScript学习_第9章_window对象
- 【JavaScript学习】事件:事件处理程序
- JavaScript第五天学习--事件总结
- 【JavaScript学习】事件:事件对象
- JavaScript window.document的属性、方法和事件小结
- JavaScript事件类型学习
- Javascript冒泡事件学习
- javascript学习七:事件处理
- HTML、CSS和JavaScript学习四(Window对象之alert、confirm、prompt、open、onload...)