JavaScript的错误处理之onerror事件的使用方法

本文介绍了一种使用onerror事件处理JavaScript错误的方法,该方法能够有效提高调试效率,并提供了详细的使用示例。文章还讨论了不同浏览器下onerror事件的行为一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

JavaScript对于我来说一直是个很高深莫测的东西,尤其是在错误处理这方面。Firefox出来之前编写JavaScript真的很头痛,程序运行不了害我不得不认真检查程序,反复的使用Alert验证每一段代码是否运行正常,费时也费力。也许很多人笑我为什么不用一些调试软件或是插件呢?原因很简单:因为我当时不知道。现在知道了也很少用了,因为有了Firefox!

这几天无意之中发现了JavaScript一个错误处理的事件,顺便研究了一下它的使用方法,猛然发现真的比alert要效率的多呀。

onerror事件:当程序出现错误时,error事件会在window对象上触发。实例一:onerror的简单应用

onerror事件实例一
ContractedBlock.gif ExpandedBlockStart.gif Code

onerror事件实例一
<script type="text/javascript">    
window.onerror 
= function() {    
    alert(
"真不幸,又出错了");    
}    
   
phplamp();    
</script>   


运行实例一:会弹出“真不幸,又出错了”。因为:phplamp()函数并未在程序中并不存在。

注意:onerror事件必需在此文档其它Javascript程序前!

实例二:使用onerror事件的参数确定错误的详细信息。onerror事件有三个参数,第一个:错误的描述信息;第二个:错误出现的文件URL地址;第三个:错误所在的行号。

ContractedBlock.gif ExpandedBlockStart.gif Code
onerror事件实例二
<script type="text/javascript">    
window.onerror 
= function(msg, url, line) {    
    alert(    
    
"真不幸,又出错了\n"   
    
+ "\n错误信息:" + msg    
    
+ "\n所在文件:" + url    
    
+ "\n错误行号:" + line    
    );    
}    
   
phplamp();    
</script>   

运行实例二即弹出了错误的详细信息。
 

注:此调试方法试用于IE,Firefox。Opera,chrome测试未通过。Safari未测试。

 

我们一般通过函数名传递的方式(引用的方式)将要执行的操作函数传递给onerror事件,如window.onerror=reportError;window.onerror=function(){alert('error')},但我们可能不知道该事件触发时还带有三个默认的参数,他们分别是错误信息,错误页面的url和错误行号。

 

ContractedBlock.gif ExpandedBlockStart.gif Code
<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在IE和FF等浏览器执行方式是一样的,而且都包含这三个参数。


转载于:https://www.cnblogs.com/shengel/archive/2009/08/13/1545098.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值