js中的异常处理try...catch使用介绍


Posted in Javascript onSeptember 21, 2013

在JavaScript可以使用try...catch来进行异常处理。例如:

try { foo.bar();} catch (e) { alert(e.name + ": " + e.message);}

目前我们可能得到的系统异常主要包含以下6种:

EvalError: raised when an error occurs executing code in eval()
RangeError: raised when a numeric variable or parameter is outside of its valid range
ReferenceError: raised when de-referencing an invalid reference
SyntaxError: raised when a syntax error occurs while parsing code in eval()
TypeError: raised when a variable or parameter is not a valid type
URIError: raised when encodeURI() or decodeURI() are passed invalid parameters

上面的六种异常对象都继承自Error对象。他们都支持以下两种构造方法:

new Error();new Error("异常信息");

手工抛出异常的方法如下:

try { throw new Error("Whoops!");} catch (e) { alert(e.name + ": " + e.message);}

如要判断异常信息的类型,可在catch中进行判断:
try { foo.bar();} catch (e) { if (e instanceof EvalError) { alert(e.name + ":" + e.message); } else if (e instanceof RangeError) { alert(e.name + ": " + e.message); } // etc }

Error具有下面一些主要属性:

description: 错误描述 (仅IE可用).
fileName: 出错的文件名 (仅Mozilla可用).
lineNumber: 出错的行数 (仅Mozilla可用).
message: 错误信息 (在IE下同description)
name: 错误类型.
number: 错误代码 (仅IE可用).
stack: 像Java中的Stack Trace一样的错误堆栈信息 (仅Mozilla可用).

因此为了更好的了解错误信息我们可以将catch部分改为如下形式:

try { foo.bar();} catch (e) { if (browserType != BROWSER_IE) { 
alert("name: " + e.name + "message: " + e.message + "lineNumber: " + e.lineNumber + "fileName: " + e.fileName + "stack: " + e.stack); 
} else { 
alert("name: " + e.name +"errorNumber: " + (e.number & 0xFFFF ) + "message: " + e.message"); 
} }

JavaScript中的throw命令事实上可以抛出任何对象,并且我们可以在catch接受到此对象。例如:
try { throw new Date(); // 抛出当前时间对象 } catch (e) { alert(e.toLocaleString()); // 使用本地格式显示当前时间 }
Javascript 相关文章推荐
ajax 文件上传应用简单实现
Mar 03 Javascript
Javascript 修改String 对象 增加去除空格功能(示例代码)
Nov 30 Javascript
jQuery中:radio选择器用法实例
Jan 03 Javascript
jQuery实现的AJAX简单弹出层效果代码
Nov 26 Javascript
原生js实现秒表计时器功能
Feb 16 Javascript
微信小程序使用template标签实现五星评分功能
Nov 03 Javascript
jQuery选择器之基本选择器用法实例分析
Feb 19 jQuery
优雅的处理vue项目异常实战记录
Jun 05 Javascript
js图片查看器插件用法示例
Jun 22 Javascript
微信JS-SDK实现微信会员卡功能(给用户微信卡包里发送会员卡)
Jul 25 Javascript
no-vnc和node.js实现web远程桌面的完整步骤
Aug 11 Javascript
js实现页面图片消除效果
Mar 24 Javascript
使用JS读秒使用示例
Sep 21 #Javascript
用RadioButten或CheckBox实现div的显示与隐藏
Sep 21 #Javascript
JS.GetAllChild(element,deep,condition)使用介绍
Sep 21 #Javascript
JS.findElementById()使用介绍
Sep 21 #Javascript
JS.getTextContent(element,preformatted)使用介绍
Sep 21 #Javascript
javascript实现原生ajax的几种方法介绍
Sep 21 #Javascript
使用javascript实现页面定时跳转总结篇
Sep 21 #Javascript
You might like
咖啡语言
2021/03/03 咖啡文化
队列在编程中的实际应用(php)
2010/09/04 PHP
Yii 2.0自带的验证码使用经验分享
2017/06/19 PHP
ThinkPHP框架整合微信支付之刷卡模式图文详解
2019/04/10 PHP
JavaScript 学习初步 入门教程
2010/03/25 Javascript
javascript中不等于的代码是什么怎么写
2013/12/29 Javascript
javascript实现一个数值加法函数
2015/06/26 Javascript
JavaScript模版引擎的基本实现方法浅析
2016/02/15 Javascript
理解javascript定时器中的setTimeout与setInterval
2016/02/23 Javascript
基于JS判断iframe是否加载成功的方法(多种浏览器)
2016/05/13 Javascript
BootStrap iCheck插件全选与获取value值的解决方法
2016/08/24 Javascript
AngularJS使用angular.bootstrap完成模块手动加载的方法分析
2017/01/19 Javascript
flexslider.js实现移动端轮播
2017/02/05 Javascript
基于easyui checkbox 的一些操作处理方法
2017/07/10 Javascript
Node.js  REPL (交互式解释器)实例详解
2017/08/06 Javascript
微信小程序实现轮播图效果
2017/09/07 Javascript
浅谈react前后端同构渲染
2017/09/20 Javascript
cdn模式下vue的基本用法详解
2018/10/07 Javascript
vue-model实现简易计算器
2020/08/17 Javascript
windows下python模拟鼠标点击和键盘输示例
2014/02/28 Python
python通过urllib2获取带有中文参数url内容的方法
2015/03/13 Python
在Python的Django框架中使用通用视图的方法
2015/07/21 Python
Python用61行代码实现图片像素化的示例代码
2018/12/10 Python
如何基于python操作excel并获取内容
2019/12/24 Python
Django import export实现数据库导入导出方式
2020/04/03 Python
Python新手如何理解循环加载模块
2020/05/29 Python
python cv2.resize函数high和width注意事项说明
2020/07/05 Python
Boden澳大利亚官网:英国在线服装公司
2018/08/05 全球购物
绿色家庭事迹材料
2014/05/01 职场文书
工作经常出错的检讨书
2014/09/13 职场文书
母亲节寄语大全
2015/02/27 职场文书
庆祝教师节主题班会
2015/08/17 职场文书
寒假致家长的一封信
2015/10/10 职场文书
创业项目(超低成本创业项目)
2019/08/16 职场文书
手残删除python之后的补救方法
2021/06/26 Python
CSS元素定位之通过元素的标签或者元素的id、class属性定位详解
2022/09/23 HTML / CSS