DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript技巧 >> javascript 中的try catch應用總結
javascript 中的try catch應用總結
編輯:JavaScript技巧     

javascript 中的try catch應用總結

實例代碼:

<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種:

  1. EvalError: raised when an error occurs executing code in eval() 
  2. RangeError: raised when a numeric variable or parameter is outside of its valid range 
  3. ReferenceError: raised when de-referencing an invalid reference 
  4. SyntaxError: raised when a syntax error occurs while parsing code in eval() 
  5. TypeError: raised when a variable or parameter is not a valid type 
  6. 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具有下面一些主要屬性:

  1. description: 錯誤描述 (僅IE可用). 
  2. fileName: 出錯的文件名 (僅Mozilla可用). 
  3. lineNumber: 出錯的行數 (僅Mozilla可用). 
  4. message: 錯誤信息 (在IE下同description) 
  5. name: 錯誤類型. 
  6. number: 錯誤代碼 (僅IE可用). 
  7. 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()); // 使用本地格式顯示當前時間 
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved