try catch finally的理解


定義以及用法:

try/catch/finally 語句用於處理代碼中可能出現的錯誤信息。

錯誤可能是語法錯誤,通常是程序員造成的編碼錯誤或錯別字。也可能是拼寫錯誤或語言中缺少的功能(可能由於瀏覽器差異)。

try語句允許我們定義在執行時進行錯誤測試的代碼塊。

catch 語句允許我們定義當 try 代碼塊發生錯誤時,所執行的代碼塊。

finally 語句在 try 和 catch 之后無論有無異常都會執行。

注意: catch 和 finally 語句都是可選的,但你在使用 try 語句時必須至少使用一個。

提示: 當錯誤發生時, JavaScript 會停止執行,並生成一個錯誤信息。使用 throw 語句 來創建自定義消息(拋出異常)。如果你將 throwtrycatch一起使用,就可以控制程序輸出的錯誤信息。

 

總結:

try { //執行的代碼,其中可能有異常。一旦發現異常,則立即跳到catch執行。否則不會執行catch里面的內容 } 

catch { //除非try里面執行代碼發生了異常,否則這里的代碼不會執行 } 

finally { //不管什么情況都會執行,包括try catch 里面用了return ,可以理解為只要執行了try或者catch,就一定會執行 finally } 

案例:

	(function (){
		try{
			throw new Error();
		}catch(x){
			var x = 1, y = 2;
			console.log(x); // 1
		}
		console.log(x); //undefined
		console.log(y); //2
	}());

下面說一下js錯誤Error對象的詳解:

 一·概念

error,指程序中的非正常運行狀態,在其他編程語言中稱為“異常”或“錯誤”。解釋器會為每個錯誤情形創建並拋出一個Error對象,其中包含錯誤的描述信息。

ECMAScript定義了六種類型的錯誤。除此之外,還可以使用Error構造方法創建自定義的Error對象,並使用throw語句拋出該對象。

六種錯誤:

  • ReferenceError:找不到對象時
  • TypeError:錯誤的使用了類型或對象的方法時
  • RangeError:使用內置對象的方法時,參數超范圍
  • SyntaxError:語法寫錯了
  • EvalError:錯誤的使用了Eval   
  • URIError:URI錯誤

二·錯誤處理

即使程序發生錯誤,也保證不異常中斷的機制。

 

try{
    可能發生錯誤的代碼
}catch(err){
    只有發生錯誤時才執行的代碼
}finally{
    無論是否出錯,肯定都要執行的代碼
}

 

使用要點:

  • 使用try包裹的代碼,即使不出錯,效率也比不用try包裹的代碼低;
  • 在try中,盡量少的包含可能出錯的代碼;
  • 無法提前預知錯誤類型的錯誤,必須用try catch捕獲;
  • finally可以省略;

三·拋出自定義錯誤

何時:如果函數的定義者,需要告知調用者使用過程中的錯誤;

如何:throw new Error("提示文字");

// 甲:定義函數的人
function round(num, d){
    if(!isNaN(num) && !isNaN(d)){
        num *= Math.pow(10, d);
        return num;
    }else{
        // 拋出自定義錯誤
        throw new Error("參數必須是數字");  
    }
}

// 乙:調用函數的人
var d = parseInt(prompt('請輸入數字'));
try{
    alert(round(123.456, d));
}catch(err){
    alert(err.message);  // 接住拋出的自定義錯誤
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM