js 的try catch應用

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") 
} 

在JavaScript能夠使用try...catch來進行異常處理。例如:  ide

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

目前咱們可能獲得的系統異常主要包含如下6種:oop

  • 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對象。他們都支持如下兩種構造方法:spa

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

手工拋出異常的方法以下:code

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具備下面一些主要屬性:blog

  • 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接受到此對象。例如:ip

try {
 throw new Date(); // 拋出當前時間對象 
} catch (e) {
 alert(e.toLocaleString()); // 使用本地格式顯示當前時間 
}
相關文章
相關標籤/搜索