`

js异常处理

阅读更多

javascript同java一样,都有异常处理机制。在javascript中,也是用try...catch来进行异常处理。例如: 

Js代码  收藏代码
  1. try {     
  2.      fo.bar();     
  3. catch (e) {     
  4.      alert(e.name + ": " + e.message);     
  5. }    
  6. try {  
  7.  fo.bar();  
  8. catch (e) {  
  9.  alert(e.name + ": " + e.message);  
  10. }  

目前我们可能得到的系统异常主要包含以下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("异常信息"); 

每当产生运行时错误,就产生 Error 对象的一个实例以描述错误。该实例有两个固有属性保存错误的描述(description 属性)和错误号(number 属性)。 


Error 对象也可以用如上所示方法显式创建,或用 throw 语句抛掉。在两种情况下,都可以添加选择的任何属性,以拓展 Error 对象的能力。 


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


Js代码  收藏代码
  1. try {  
  2.  throw new Error("Whoops!");  
  3. catch (e) {  
  4.  alert(e.name + ": " + e.message);alert(e.name + ": " + e.description);//IE中两者结果一样,都是Whoops!  
  5. }  

如要判断异常信息的类型,可在catch中进行判断: 


Js代码  收藏代码
  1. try {     
  2.      fo.bar();     
  3. catch (e) {     
  4.     if (e instanceof EvalError) {     
  5.          alert(e.name + ":" + e.message);     
  6.      }     
  7.     else if (e instanceof RangeError) {     
  8.          alert(e.name + ": " + e.message);     
  9.      }     
  10.     // etc     
  11. }    
  12. try {  
  13.  fo.bar();  
  14. catch (e) {  
  15.  if (e instanceof EvalError) {  
  16.   alert(e.name + ":" + e.message);  
  17.  }   
  18.  else if (e instanceof RangeError) {  
  19.   alert(e.name + ": " + e.message);  
  20.  }   
  21.  // etc   
  22. }  



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

description: 错误描述 (仅IE可用). 
fileName: 出错的文件名 (仅Mozilla可用). 
lineNumber: 出错的行数 (仅Mozilla可用). 
message: 错误信息 (在IE下同description) 
name: 错误类型. 
number: 错误代码 (仅IE可用). 
stack: 像Java中的Stack Trace一样的错误堆栈信息 (仅Mozilla可用). 
因此为了更好的了解错误信息我们可以将catch部分改为如下形式: 

Js代码  收藏代码
  1. try {     
  2.      fo.bar();     
  3. catch (e) {     
  4.     if (browserType != BROWSER_IE) {                                 
  5.          alert("name: " + e.name +     
  6.             "message: " + e.message +     
  7.             "lineNumber: " + e.lineNumber +     
  8.             "fileName: " + e.fileName +     
  9.             "stack: " + e.stack);             
  10.      }     
  11.     else {                         
  12.          alert("name: " + e.name +          
  13.             "errorNumber: " + (e.number & 0xFFFF ) +     
  14.             "message: " + e.message");             
  15.      }     
  16. }    
  17. try {  
  18.  fo.bar();  
  19. catch (e) {  
  20.  if (browserType != BROWSER_IE) {                              
  21.   alert("name: " + e.name +   
  22.    "message: " + e.message +   
  23.    "lineNumber: " + e.lineNumber +   
  24.    "fileName: " + e.fileName +   
  25.    "stack: " + e.stack);          
  26.  }   
  27.  else {                      
  28.   alert("name: " + e.name +       
  29.    "errorNumber: " + (e.number & 0xFFFF ) +   
  30.    "message: " + e.message");          
  31.  }   
  32. }  


JavaScript中的throw命令事实上可以抛出任何对象,并且我们可以在catch接受到此对象。例如:   
Js代码  收藏代码
  1.     
  2. try {     
  3.     throw new Date();   // 抛出当前时间对象     
  4. catch (e) {     
  5.      alert(e.toLocaleString());  // 使用本地格式显示当前时间     
  6. }   

<!--EndFragment-->
分享到:
评论

相关推荐

    javaScript异常处理文档

    javaScript异常处理文档,当遇到JavaScript等异常问题时可翻阅本文档寻找答案

    JavaScript异常处理

    JavaScript异常处理是编程中至关重要的一个环节,它用于管理和修复代码执行过程中可能出现的错误或异常情况。异常处理机制使得程序能够在遇到错误时不会立即终止,而是有机会进行适当的恢复或者给出反馈,增强了程序...

    javascript 异常处理使用总结

    JavaScript中的异常处理是编程中非常重要的一个环节,它允许我们优雅地处理程序运行时可能出现的错误,避免程序因意外情况而中断。本文将详细介绍JavaScript中如何使用`try...catch...finally`语句进行异常处理以及...

    浅谈JavaScript异常处理语句

    运行时的错误统称为异常,为了能在错误发生时得到一个处理的机会,JavaScript提供了异常处理语句。包含try-catch、try-catch-finally和throw. try-catch语句 try{ tryStatements } catch(exception){ ...

    javascript异常处理实现原理详解

    JavaScript异常处理是编程中不可或缺的一部分,它允许开发者在程序遇到错误时优雅地处理问题,而不是让程序崩溃。本文将深入探讨JavaScript异常处理的实现原理,包括异常的基本概念、如何使用try...catch...finally...

    reactnative异常处理库

    React Native 异常处理库是专门为在React Native框架下开发的混合移动应用提供错误管理和调试支持的工具。React Native允许开发者使用JavaScript编写原生移动应用,但JavaScript代码的运行环境中可能会遇到各种错误...

    JavaScript 异常处理 详解

    总结来说,JavaScript异常处理是一门艺术,需要开发者对异步编程和错误处理机制有深刻的理解。异常处理不仅能够提升程序的健壮性,减少用户的困扰,还能帮助开发者更好地定位和修复程序中的漏洞,从而提供更加流畅和...

    JavaScript错误与异常处理

    JavaScript错误与异常处理是编程实践中不可或缺的部分,尤其是在JavaScript这样的脚本语言中,错误处理显得尤为重要。JavaScript中的错误分为两种主要类型:语法错误和运行错误。语法错误,也称为错误(Error),是...

    JS异常处理try..catch语句的作用和实例

    JavaScript异常处理是程序设计中确保代码健壮性的重要机制。它允许开发者在代码执行过程中遇到错误时,能够捕获这些错误并以一种可控的方式处理它们。在JavaScript中,try..catch语句是最常用的异常处理机制。 首先...

    javascript编程异常处理实例小结

    本文实例总结了javascript编程异常处理的方法。分享给大家供大家参考,具体如下: 前言:在前一篇《asp.net开发中常见公共捕获异常方式总结》,我们整理总结了asp.net服务端的异常处理。这一篇接着前文,简单总结并...

    详解JavaScript中的异常处理方法

    JavaScript中的异常处理是编写健壮脚本的重要组成部分。在JavaScript中,主要的异常处理方法包括try...catch语句,throw语句以及finally子句的使用。异常处理机制能够在程序运行期间遇到错误时,提供一种控制错误...

    分享代码,基于MicroSoftAjax的JS代码之1:异常处理

    在这个"基于MicroSoftAjax的JS代码之1:异常处理"分享中,我们将深入探讨如何有效地在JavaScript和MicroSoftAjax中实施异常管理。 异常处理是程序设计中的一个关键部分,它允许程序员捕获并处理运行时发生的错误,...

    全局异常处理的实现

    在JavaScript中,全局异常处理通常在事件循环的顶层进行。在Node.js环境中,可以使用`process.on('uncaughtException', handler)`监听未捕获的异常。在浏览器环境中,可以监听`window.onerror`事件来捕获脚本错误。...

    JS异常处理的一个想法(sofish)

    JavaScript异常处理是前端开发中必不可少的部分,因为网络问题、浏览器兼容性、缓存问题以及其他因素,JavaScript代码在运行时可能会抛出异常。本文主要探讨了一种处理这些异常的方法,包括异常的收集和使用。 首先...

    JS中的异常处理方法分享

    } 下面是为了获取js异常信息,方便开发者找回问题 1,try…catch… 代码如下:[removed]var txt=””function message(){try { adddlert(“Welcome guest!”) }catch(err) { txt=”本页中存在错误。\n\n” txt+...

Global site tag (gtag.js) - Google Analytics