A JavaScript Fancier

伟大的javascript技术研究中...

  IT博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  304 随笔 :: 0 文章 :: 479 评论 :: 0 Trackbacks


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

<script type="text/javascript">
window.onerror
=testError;
function testError(){
 arglen
=arguments.length;
 
var errorMsg="参数个数:"+arglen+"";
 
for(var i=0;i<arglen;i++){
  errorMsg
+="\n参数"+(i+1)+""+arguments[i];
 }
 alert(errorMsg);
 window.onerror
=null;
 
return true;
}

function test(){
error
}
test()
</script>


首先将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等浏览器执行方式是一样的,而且都包含这三个参数。


posted on 2007-10-06 21:15 Yemoo'S JS Blog 阅读(4912) 评论(5)  编辑 收藏 引用 所属分类: javascript语法基础

评论

# re: window.onerror事件学习新收获 2007-10-15 09:40 未知数据
请教:
1、通过在函数末尾加上return true,可以在函数出错时不会弹出系统的错误信息(IE)。
何意?  回复  更多评论
  

# re: window.onerror事件学习新收获 2007-10-15 10:47 Yemoo'S JS Blog
@未知数据
如果不加return true;程序出错时会在浏览器左下角显示黄色的叹号(错误),根据浏览器配置可能还会弹出一个错误信息的提示,加上这句之后等于屏蔽了错误的显示,左下角的黄色叹号和错误提示就不会出现了。  回复  更多评论
  

# re: window.onerror事件学习新收获 2007-10-21 23:58 Azaling
仔细研究了一下,学习到了,感谢楼主!  回复  更多评论
  

# re: window.onerror事件学习新收获 2009-04-02 17:15 coffeebenben
@Yemoo'S JS Blog
这样只是避免问题的发生,而不是解决问题。还有,你只是不让IE提示你写的代码有问题,但问题还是存在的。  回复  更多评论
  

# re: window.onerror事件学习新收获 2010-08-24 10:16 G2000
又学到一招了,感谢博主  回复  更多评论
  

只有注册用户登录后才能发表评论。