js 异常处理

<script language="javascript">
try
{
throw new Error(10,"asdasdasd")
}
catch (e)
{
alert(e.message);
alert(e.description)
alert(e.number)
alert(e.name)
throw new Error(10,"asdasdasd")
} 

</script>  
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()); // 使用本地格式显示当前时间
}

实例
 1 //js调用app接口  action 方法名  param  参数 json字符串
 2 function Interface(action){
 3     try{
 4         //获取访问终端类型
 5         var DeviceType=getDeviceType();
 6         var param=arguments[1]?arguments[1]:‘‘;
 7         if(DeviceType==‘android‘){
 8             JavaScriptInterface[action](param);
 9         }else if(DeviceType==‘ios‘){
10             callFun(action,param);
11         }else{
12             alert("方法名:"+action+",参数:"+param);
13         }
14     }catch(e){
15         alert(e.message);
16     }
17 }
时间: 2024-08-11 10:57:13

js 异常处理的相关文章

前端JS 异常处理实践

前端异常处理,常见的场景是在"异步请求"的操作过程当中,所谓"异常"---就是"不正常",程序的运行不符合我们的预期. 程序"正常"的处理,是我们在开发过程当中的"重中之重",是必要的"硬性指标". 而"异常处理",很多时候可能连"指标"都没有,更谈不上什么"硬性指标"了,所以,在开发当中是很容易被忽略的一个"主题&q

4.JS异常处理和事件处理

异常: 1.异常:当JS引擎执行JS代码时,发生了错误,导致程序停止运行. 2.异常抛出:当异常产生,并且将这个异常生成一个错误信息. 3.异常捕获: try{ 发生异常的代码块; }catch(err){ 错误处理信息: } 4.Throw语句: 通过throw语句创建一个自定义错误: 通常throw与try{}catch{}配合使用. 写一个事例吧: function demo() { try{ var e=10; if(e==10){ throw "不能等于10啊"; }catc

angular中的异常机制与异常之外的处理

在查阅angularjs的官方文档发现: 文档中提到了throw异常 angular.module('exceptionOverride', []).factory('$exceptionHandler', function() { return function(exception, cause) { exception.message += ' (caused by "' + cause + '")'; throw exception; }; }); 同时下面也提到了捕获异常 tr

Atitit.js javascript异常处理机制与java异常的转换.js exception process Voae

Atitit.js javascript异常处理机制与java异常的转换.js exception processVoae 1. 1. javascript异常处理机制 1 2. 2. Web前后台异常的统一处理 1 3.  java异常转换为js异常 1 3. -------------详细代码 2 1. 1. javascript异常处理机制 Throw str Not throw error  ..cause ie,ff error obj is diff.. 2. 2. Web前后台异常

Atititjs javascript异常处理机制与java异常的转换.js exception process

Atititjs javascript异常处理机制与java异常的转换.js exception process 1. javascript异常处理机制 Throw str Not throw error  ..cause ie,ff error obj is diff.. 2. Web前后台异常的统一处理 不个java异常转换成个js异常走ok... 作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:[email protected] 转载请注明来源: http://blog.csd

js构建ui的统一异常处理方案(二)

上一篇文章,我分析了同步代码做异常处理是基于责任链模式,而通过try.catch等语句可以很容易地实现这种责任链模式.但是如果是异步调用,我们无法直接通过try.catch语句实现责任链模式,并且通过一个demo证明使用回调函数的方式去实现去实现异常处理的责任链模式是非常繁琐而且代码难以规范的,适用性不高.有没有什么方式能够使得异步js的责任链模式能够更加简单地实现呢? 对于这个问题,我们还是先回到js异步调用上,随着node和npm的普及,js异步调用也越来越被大家重视,于是乎npm引用了一个

js中eval,arguments与异常处理的用法-基础知识总结------彭记(017)

eval的使用: <script> /*eval的作用: * 1.将字符串当成js代码来执行 * 2.可以将json格式的字符串转换为js对象*/ /*eval("var age = 30;"); console.log(age); eval("alert(123)"); var va = eval("1+1"); console.log(va);*/ //({"name":"rose",&qu

js构建ui的统一异常处理方案(三)

笔者之前分析了如何实现js的责任链异常处理的方法,通过promise这个异步模型,我们能够对同步方法和异步方法的两种情况,均可以实现责任链模式.有了这些武器,我们就可以开始设计ui的统一异常处理方案了. 1.统一异常处理方案 这里所谓统一异常处理方案,其实就是指对那些底层无法处理的,一层层抛到了边界类的异常,在边界类中根据异常的不同类型,做出不同处理方案的处理策略.为了能在边界类中对异常类型做出判断,我们需要将常用的异常类型定义出来,再将原始异常包装为这些系统内部定义的异常类型.所以,整个统一处

JS中异常处理的理解

[转]JS中异常处理的理解 JS里的异常处理 JS的异常捕获与处理可以从它的 try-catch 语法结构说起,具体形式如下: try{ ... //异常的抛出 }catch(e){ ... //异常的捕获与处理 }finally{ ... //结束处理 } 其中,try块: try块包含的是可能产生异常的代码,在这里面直接或者在里面通过调用函数里间接抛出的异常都可以捕获到.部分浏览器还可以找到具体抛出的位置.详见e.stack. catch块: catch块,是捕获异常,并处理异常的地方,包括