首页 »Javascript教程 » window.onerror:javascript window.onerror事件学习新收获 »正文window.onerror:javascript window.onerror事件学习新收获来源: 发布时间:星期六, 2008年12月27日 浏览:91次 评论:0
在捕获js时我们通常使用try{}catch(e){}方式然后通过e.errorMessage等方式获取信息然后报告但对于onerror事件可能很少问津我们是否研究过如何报告所在行号?如果想过这个是否也被这个问题所困扰过是否认为在js里不可能捕获行号呢?其实本人就遇到上述几个问题今日读某人写段js代码顿然发现了onerror事件要说onerror这个时间也是n久以前就知道了但对于其所带有 3个参数和其特殊性质却直没有去了解过经过自己研究测试对onerror事件有了些新认识和了解在页面没有时window.onerror事件是不存在也就是null(废话!没出错如果onerror出现还正常吗?)我们般通过名传递方式(引用方式)将要执行操作传递给onerror事件如window.onerror=reportError;window.onerror=function{alert('error')}但我们可能不知道该事件触发时还带有 3个默认参数他们分别是信息页面url和行号要知道这个可是事件就如onclick和onmouseover等事件样但它是有参数我们可以这样测试
点击运行可以看到效果: [Ctrl+A 全选 提示:你可先修改部分代码,再按运行] 首先将testError思路方法绑定给onerror事件然后在test思路方法里触发个在IE中执行时我们发现如下提示: --------------------------- Microsoft Internet Explorer --------------------------- 参数个数:3个 参数1:'error' 未定义 参数2:file://E:\yanwei\test\testError.html 参数3:14 --------------------------- 确定 --------------------------- 可以发现当出错时testError捕获到了 3个参数通过将绑定到onerror事件就可以在页面出错时捕获以上 3个参数 在测试中还发现以下些问题: 1、通过在末尾加上 true可以在出错时不会弹出系统信息(IE) 2、如果页面出现多次只捕获第次并进行处理然后终止后面执行 3、onerror事件并不能捕获所有只能捕获外或内(??这个是什么意思可不是开玩笑呢)如 adasdf; function test{ aaaa; } 可以捕获到adasdf未定义 function test{ aaaa; } 可以捕获到aaaa未定义而对于functiona test{}或function testdd{} 却不能捕获而会直接弹出系统信息 4、onerror在IE和FF等浏览器执行方式是样而且都包含这 3个参数 0
相关文章
读者评论发表评论 |