本站业务范围:1、PC端软件开发、网站开发 2、移动端APP、网站、微信接口、微商城开发 3、视频教程、课程设计和辅导 4、单片机开发 5、串口通讯调试
 当前位置:文章中心 >> 常见错误调试
立即购买视频教程 JS错误处理与调试的方法
夜鹰教程网 来源:www.yyjcw.com 日期:2019-1-4 13:15:13
JS错误处理与调试的方法 

这篇文章不能解决你的问题?我们还有相关视频教程云课堂 全套前端开发工程师培训课程

微信号:yyjcw10000 QQ:1416759661  远程协助需要加QQ!

业务范围:视频教程|程序开发|在线解答|Demo制作|远程调试| 点击查看相关的视频教程

技术范围:全端开发/前端开发/webapp/web服务/接口开发/单片机/C#/java/node/sql server/mysql/mongodb/android/。 



下面总结一下JS错误处理与调试的方法 

方法1:用alert() 和document.write()方法监视变量值。 

alert()在弹出对话框显示变量值的同时,会停止代码的继续运行,直到用户单击“确定”按钮,而document.write()则在输出值后继续运行代码。调试JS时可以根据具体情况来选择这种方法。 

例如下面代码:将数组a中以1开头的数据添加到数组b中 

复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

var a=["123","456","789","111"]; 

function AlertMessage() 

var b=new Array("1111"); 

for(var i=0;i<a.length;i++) 

if(a[i].indexOf("1")!=0) 

alert(a[i]); 

b.push(a[i]); 

</script> 

</head> 

<body > 

<input type="button" value="点我" onclick="AlertMessage()"/> 

</body> 

</html> 


如果加入的值比较多,则可以使用document.writer()方法,避免反复点击确定按钮。 

方法2:用onerror事件找到错误: 

当页面出现异常时,error事件会在window对象上触发,它能够在一定程序上告诉开发者出现了错误,并帮助开发者找到错误所在,如下例: 

复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

window.onerror=function() 

alert("不好意思,出错了!"); 

</script> 

</head> 

<body onload="NonExist()" > 

</body> 

</html> 


代码运行body标记的onload事件时调用了一个不存在的函数NonExist(),产生了错误,如下图:


 

同时,浏览器本身的代码调试错误也出现了: 

要避免浏览器自己的错误提示很简单,只需要要onerror事件的处理函数最后返回ture便可,代码如下:


复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

window.onerror=function() 

alert("不好意思,出错了!"); 

return true;//屏蔽系统事件 

</script> 

</head> 

<body onload="NonExist()" > 

</body> 

</html> 


但这样处理对于解决错误并没有任何的帮助。其实onerror还提供了3个参数来确定错误的性质,代码: 

复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

window.onerror=function(message,url,line) 

alert("不好意思,出错了:\n错误提示:"+message+"\nUrl:"+url+"\n行号:"+line); 

return true;//屏蔽系统事件 

</script> 

</head> 

<body onload="NonExist()" > 

</body> 

</html> 


在IE运行时的提示:



在Firefox运行的提示

  

在IE浏览器中发生error事件时,正常的代码会继续执行,所有的变量和数据都保存下来,并可以通过onerror事件处理函数访问。而在Firefox中,正常的代码执行都会结束,同时所有的错误发生之前的变量和数据都会被销毁. 

方法3:用try….catch语句找到错误 


复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

try 

alert("这个是try...catch的例子"); 

alert(hello); 

catch(exception) 

var error=""; 

for(var i in exception) 

error+=i+":"+exception[i]+"\n"; 

alert(error); 

</script> 

</head> 

<body> 

</body> 

</html> 


IE运行时的提示:

 

Firefox运行时的提示:

 

通过try…..catch可以很轻松的找到错误的问题,不过可惜的是该语句并不能很好地处理语句错误。如下例:

复制代码 代码如下:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml" > 

<head> 

<title>无标题页</title> 

<script type="text/javascript"> 

try 

alert("这个是try...catch的例子")); 

catch(exception) 

var error=""; 

for(var i in exception) 

error+=i+":"+exception[i]+"\n"; 

alert(error); 

</script> 

</head> 

<body> 

</body> 

</html> 


try语句里面出现了括号不匹配的错误,而整个代码并没有运行catch中的模块,而是浏览器弹出了错误提示框,如下图:


方法4:使用Firefox错误控制台调试:


在Firefox菜单栏中选择“工具”->“错误控制台”,便可以打开它,所有浏览中运行的错误,警告,消息都会传错误控制台,如下:


Firefox提示的错误信息要比IE全面而且准确的多。


方法5:使用Firefox插件FireBug


Firebug是Firefox下的一款开发类插件,现属于Firefox的五星级强力推荐插件之一。它集HTML查看和编辑、Javascript控制台、网络状况监视器于一体,是开发JavaScript、CSS、HTML和Ajax的得力助手。Firebug如同一把精巧的瑞士军刀,从各个不同的角度剖析Web页面内部的细节层面,给Web开发者带来很大的便利。具体如何安装使用FireBug可参考这篇文章:http://apps.hi.baidu.com/share/detail/15314208


方法6:使用Miscrosoft Script Debugger调试:


在IE菜单栏中打开“工具”->“Internet选项“,选择”高级“,将”禁用脚本调试“复选框的勾去掉。


 

具体如何使用就不介绍了。


方法7:使用IE下的JS调试工具companion.js


一款像firefox中的firedebug工具类似的一个工具包,它的特点就是可以有好的提示错误,并且可以在IE浏览器下方出现控制台输出.方便及时调试。


具体可参考这篇文章:http://hi.baidu.com/argv/blog/item/f4efe67ac370f7e12f73b3ad.html


还有其他JS调试工具就不一一介绍了,大家也可以介绍多几种比较好的JS错误处理方法或JS调试工具。


复制链接 网友评论 收藏本文 关闭此页
上一条: js容错语句,就是js出错也不提示错…  下一条: 对一个或多个实体的验证失败。有关详细…
夜鹰教程网成立于2008年,目前已经运营了将近 13 年,发布了大量关于 html5/css3/C#/asp.net/java/python/nodejs/mongodb/sql server/android/javascript/mysql/mvc/easyui/vue/echarts原创教程。 我们一直都在坚持的是:认证负责、一丝不苟、以工匠的精神来打磨每一套教程,让读者感受到作者的用心。我们默默投入的时间,确保每一套教程都是一件作品,而不是呆板的文字和视频! 目前我们推出在线辅导班试运营,模式为一对一辅导,教学工具为QQ。我们的辅导学科包括 java 、android原生开发、webapp开发、商城开发、C#和asp.net开发,winform和物联网开发、web前端开发,但不仅限于此。 普通班针对的是国内学员,例如想打好基础的大学生、想转行的有志青年、想深入学习的程序员、想开发软件的初学者或者业余爱好者等。 就业办针对即将毕业上岗的大四学生,或者打算转行的初级开发工程师。 留学生班针对的是在欧美、加拿大、澳洲、日本、韩国、新加坡等地留学的中国学子,目的是让大家熟练地掌握编程技能,按时完成老师布置的作业,并能顺利地通过考试。 详细咨询QQ:1416759661   夜鹰教程网  基于角色的权限管理系统(c-s/b-s)。
  夜鹰教程网  基于nodejs的聊天室开发视频教程
  夜鹰教程网  Git分布式版本管理视频教程
  夜鹰教程网  MVC+EasyUI视频教程
  夜鹰教程网  在线考试系统视频教程
  夜鹰教程网  MongoDB视频教程。
  夜鹰教程网 Canvas视频教程
  夜鹰教程网 报表开发视频教程
  推荐教程/优惠活动

  热门服务/教程目录

  夜鹰教程网  新手必看,详细又全面。
  夜鹰教程网  购买教程  夜鹰教程网  在线支付-方便
  夜鹰教程网  担保交易-快捷安全   夜鹰教程网  闪电发货
  夜鹰教程网  电话和QQ随时可以联系我们。
  夜鹰教程网 不会的功能都可以找我们,按工作量收费。

客服电话:153 9760 0032

购买教程QQ:1416759661  
  热点推荐
看看你的电脑是否可以运行Windows…
断点调试其实并不是多么复杂的一件…
使用alert() 和document.write() …
js容错语句,就是js出错也不提示错…
JS错误处理与调试的方法
对一个或多个实体的验证失败。有关…
几款常用的录屏软件
中国计算机软件设计师考试大纲
  尊贵服务
夜鹰教程网 承接业务:软件开发 网站开发 网页设计 .Net+C#+VS2008+MSsql+Jquery+ExtJs全套高清完整版视频教程
  最近更新
断点调试其实并不是多么复杂的一件…
使用alert() 和document.write() …
js容错语句,就是js出错也不提示错…
JS错误处理与调试的方法
对一个或多个实体的验证失败。有关…
几款常用的录屏软件
中国计算机软件设计师考试大纲
看看你的电脑是否可以运行Windows…
  工具下载  需要远程协助? 

sql2008视频教程 c#视频教程

VIP服务:如果您的某个功能不会做,可以加我们QQ,给你做DEMO!

JQUERY  Asp.net教程

MVC视频教程  vs2012
.NET+sql开发
手机:15397600032 C#视频教程下载
微信小程序 vue.js高级实例视频教程

教程咨询QQ:1416759661


这篇文章不能解决你的问题?我们还有相关视频教程云课堂 全套前端开发工程师培训课程

微信号:yyjcw10000 QQ:1416759661  远程协助需要加QQ!

业务范围:视频教程|程序开发|在线解答|Demo制作|远程调试| 点击查看相关的视频教程

技术范围:全端开发/前端开发/webapp/web服务/接口开发/单片机/C#/java/node/sql server/mysql/mongodb/android/。 



关于我们 | 购买教程 | 网站建设 | 技术辅导 | 常见问题 | 联系我们 | 友情链接

夜鹰教程网 版权所有 www.yyjcw.com All rights reserved 备案号:蜀ICP备08011740号3