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 相关文章推荐
js+css实现增加表单可用性之提示文字
Jun 03 Javascript
JS 毫秒转时间示例代码
Sep 22 Javascript
JQuery插件开发示例代码
Nov 06 Javascript
javascript中文本框中输入法切换的问题
Dec 10 Javascript
AngularJS中的表单简单入门
Jul 28 Javascript
JS 实现缓存算法的示例(FIFO/LRU)
Mar 20 Javascript
使用webpack构建应用的方法步骤
Mar 04 Javascript
vue项目中全局引入1个.scss文件的问题解决
Aug 01 Javascript
使用layui前端框架弹出form表单以及提交的示例
Oct 25 Javascript
JavaScript简单编程实例学习
Feb 14 Javascript
JavaScript面试中常考的字符串操作方法大全(包含ES6)
May 10 Javascript
JavaScript组合继承详解
Nov 07 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
smarty模板中使用get、post、request、cookies、session变量的方法
2014/04/24 PHP
Yii清理缓存的方法
2016/01/06 PHP
PHP针对多用户实现更换头像功能
2016/09/04 PHP
IE8 引入跨站数据获取功能说明
2008/07/22 Javascript
Jquery判断radio、selelct、checkbox是否选中及获取选中值方法总结
2015/04/15 Javascript
JSON相关知识汇总
2015/07/03 Javascript
jQuery实现图片局部放大镜效果
2016/03/17 Javascript
picLazyLoad 实现图片延时加载(包含背景图片)
2016/07/21 Javascript
JS前端加密算法示例
2016/12/22 Javascript
轻松理解Javascript变量的相关问题
2017/01/20 Javascript
简单实现js无缝滚动效果
2017/02/05 Javascript
jQuery滚动插件scrollable.js用法分析
2017/05/25 jQuery
webpack-dev-server自动更新页面方法
2018/02/22 Javascript
微信小程序实现渐入渐出动画效果
2019/06/13 Javascript
微信小程序渲染性能调优小结
2019/07/30 Javascript
JS合并两个数组的3种方法详解
2019/10/24 Javascript
Python实现建立SSH连接的方法
2015/06/03 Python
分析Python读取文件时的路径问题
2018/02/11 Python
Python中循环引用(import)失败的解决方法
2018/04/22 Python
Python判断变量名是否合法的方法示例
2019/01/28 Python
详解python数据结构和算法
2019/04/18 Python
Python正则表达式实现简易计算器功能示例
2019/05/07 Python
美国派对用品及装饰品网上商店:Shindigz
2016/07/30 全球购物
Willer台湾:日本高速巴士/夜行巴士预约
2017/07/09 全球购物
怀俄明州飞钓:Platte River Fly Shop
2017/12/28 全球购物
Java的类可以定义为Protected或者Private得吗
2015/09/25 面试题
建筑经济管理专业求职信分享
2014/01/06 职场文书
迟到早退检讨书
2014/02/10 职场文书
体育教师自我鉴定
2014/02/12 职场文书
2014年最新学习全国两会精神心得
2014/03/17 职场文书
经营理念标语
2014/06/21 职场文书
《周恩来的四个昼夜》观后思想汇报范文两篇
2014/09/10 职场文书
入党介绍人考察意见
2015/06/01 职场文书
使用nginx动态转换图片大小生成缩略图
2021/03/31 Servers
php+laravel 扫码二维码签到功能
2021/05/15 PHP
修改MySQL的默认密码的四种小方法
2021/05/26 MySQL