一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript 異常處理使用總結

JavaScript中的異常可以用try..catch..finally語句來處理,也可以手動的來拋出異常。
1.使用try..catch..finally語句來處理異常
js代碼在執行過程中如果出現異常,會手動創建一個異常類對象,該異常類對象將被提交給瀏覽器,這個過程稱為“拋出異常”。當瀏覽器接收到一場對象時,會尋找能處理這一異常的代碼并把當前異常對象提交給其處理,這一過程被稱為“捕獲異常”。try..catch..finally語句的基本語法格式為:
復制代碼 代碼如下:
try{//可能拋出異常的代碼
}catch(error){//如果發生異常會執行的代碼,error為發生的異常類對象
}finally{//無條件執行的代碼
}

在上面的語句中,catch語句緊跟在try語句的后面,finally語句緊跟在catch的后面,這是一個完整的異常處理語句的寫法。其實,catch語句和finally語句都可以省略的,但是二者至少要保留其中之一和try語句結合使用。
在try塊中的語句并不一定是要拋出異常的語句,任何JavaScript語句都可以使用異常處理語句來處理,但這樣做沒有必要。當try塊中某一行的代碼拋出了異常,則該行下方的代碼將不會被執行,轉而直接執行catch塊的代碼。
在catch塊中,catch語句后面括號中的error表示捕獲到的異常對象實例,該實例包含異常的詳細信息,可以根據這些信息作出適當的處理。如果catch語句后還有finally語句,則繼續執行finally塊中的語句。
finally塊中的語句是始終被執行的語句,塊中的語句通常做一些最后的清理工作。如果在執行finally塊之前,遇到return語句、continue語句或break語句等轉移流程的語句時,那么在執行這些語句前finally塊中的代碼也要被執行。
如果在一個異常處理語句中,只包含try..finally語句而沒有補貨異常的catch語句則執行try塊中的語句后會直接執行finally塊的語句,最后再將異常拋出。
例:
復制代碼 代碼如下:
<script>
try{
var date=new Date();
date.test();//調用date的未定義的test方法;
document.wrire("try塊執行結束<br>");
}catch(error){
with(document){
write("出現了異常<br>");
write("異常類型:"+error.name+"<br>");
write("異常消息:"+error.message);
}
}finally{
document.write("異常處理完畢!");
}
</script>

結果:
出現了異常
異常類型:TypeError
異常消息:對象不支持此屬性或方法異常處理完畢!
2.手動拋出異常
除了發生運行時瀏覽器會拋出異常,開發人員也可以自己動手拋出異常。手動異常拋出的語句是throw,其基本語法格式為:
throw expression;

try catch finally 語句說明

try catch finally是Javascript語言提供的異常處理機制。語法結構如下

try { //這段代碼從上往下運行,其中任何一個語句拋出異常該代碼塊就結束運行
}catch (e) { // 如果try代碼塊中拋出了異常,catch代碼塊中的代碼就會被執行。 //e是一個局部變量,用來指向Error對象或者其他拋出的對象}finally {
 //無論try中代碼是否有異常拋出(甚至是try代碼塊中有return語句),finally代碼塊中始終會被執行。 }

try…catch…finally…語法中除了try以外catch和finally都是可選的(兩者必須要有一個),也就是說try…catch…finally…語法有以下三種形式

try{

//some code

}

catch(e){

//somecode

}

finally{

//some code

}

try{

//some code

}

catch(e){

//somecode

}

try{

//some code

}

finally{

//some code

}

如果有一定catch,一旦try中代碼拋出異常以后就是先執行catch中的代碼,然后執行finally中的代碼。如果沒有catch語句,try中的代碼拋出異常后,就會先執行finally中的語句,然后將try中拋出的異常以異常的方式繼續往上拋。

不管try代碼塊的執行時如何被終止的(出現異常、return、自然終止)finally中的語句始終會被執行,正是由于finally的這種特性,通常finally用來執行一些清理工作。如果try中代碼是以return,continue,break的方式終止的,Javascript引擎會在執行完finally中的語句以后再執行相應的try中的返回語句。

throw語句說明

 throw語句在Javascript1.4中已經實現。try的語法很簡單,如下
throw expression;

其中的expression可以是任何一種類型,也就是說throw “There is a error” 或是throw 1001都是正確的。但通常我們會拋出一個Error對象或是Error對象的子類。關于Error我們稍后介紹,先看一段throw的樣例代碼。

function factorial(x) { // If the input argument is invalid, throw an exception! if (x < 0) throw new Error("x must not be negative"); // Otherwise, compute a value and return normally for(var f = 1; x > 1; f *= x, x--) /* empty */ ; return f;}

Error對象

Error對象和它的子類是在Javascript1.5中實現的。Error的構造函數有兩種

new Error( )
new Error(message )

Error有兩個基本的屬性name和message。message用來表示異常的詳細信息。而name指的的是Error對象的構造函數。此外,不同的js引擎對Error還各自提供了一些擴展,例如mozilla提供了fileName(異常出現的文件名稱)和linenumber(異常出現的行號)的擴展,而IE提供了number(錯誤號)的支持。不過name和message是兩個基本的屬性,在firefox和ie中都能夠支持。Javascript中Error還有幾個子類EvalError, RangeError, ReferenceError, SyntaxError, TypeError, URIError,各自的意思就不在這里詳細描述了,讀者可以在我提供的參考文檔中找到相應的參考。

Javascript的異常處理機制和window.onerror句柄

Javascript代碼中出現錯誤的時候,js引擎就會根據js的調用棧逐級尋找對應的catch,如果沒有找到相應的catch handler或catch handler本身又有error或者又拋出新的error,最后就會把這個error的處理交給瀏覽器,瀏覽器會用各自不同的方式(IE以黃色三角圖案顯示在左下角,而firefix會顯示在錯誤控制臺中)顯示錯誤信息給訪問者。很多場景下,我們會覺得這種錯誤提示方式不夠友好,而且提示信息很隱蔽,那么我們機會自定義這種錯誤提示的方式嗎?答案是有,就是window.onerror屬性。

Javascript的window對象有一個特別的屬性onerror,如果你將某個function賦值給window的onerror屬性,那么但凡這個window中有Javascript錯誤出現,該function都會被調用,也就是說這個function會成為這個window的錯誤處理句柄。

// Display error messages in a dialog box, but never more than 3window.onerror = function(msg, url, line) { if (onerror.num++ < onerror.max) {  alert("ERROR: " + msg + "/n" + url + ":" + line);  return true; }}onerror.max = 3;onerror.num = 0;

onerror句柄會3個參數分別是錯誤信息提示,產生錯誤的Javascript的document ulr,錯誤出現的行號。

onerroe句柄的返回值也很重要,如果句柄返回true,表示瀏覽器無需在對該錯誤做額外的處理,也就是說瀏覽器不需要再顯示錯誤信息。而如果返回的是false,瀏覽器還是會提示錯誤信息。

window.onerror=function(){

alert(”xx”);

return true; //如果注釋掉該語句,瀏覽器中還是會有錯誤提示,反之則沒有。

}

function throwerror(){

throw new Error(”cc”);

}

1

我們在開發HTML的過程中避免不了一些Js的異常,通常我們也不可能依賴客戶打開瀏覽器的錯誤提示框(如上圖)來為我們定位bug提供線索,而利用window.onerror句柄我們就可以講錯誤提示信息顯示出來,客戶只要在錯誤出現的時候,提供相應的截屏就可以了,這點可以很好的幫助開發人員定位,分析Javascript相關的錯誤。

參考資料

Mozilla Javascript1.5核心參考

Javascript犀牛(JavaScript: The Definitive Guide)

JavaScript技術javascript 異常處理使用總結,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 99热这里只有精品88 | 天天天天色 | 91久久香蕉国产线看 | 久久伊人精品一区二区三区 | 国产成人污污网站在线观看 | 中国日韩欧美中文日韩欧美色 | 亚洲午夜18 | 影音先锋国产系列精品 | 国产玖玖在线 | 国产男人女人做性全过程视频 | 奇米影视四色7777久久精品 | 成人福利免费在线观看 | 91精品福利手机国产在线 | 天天色综 | 一起射福利 | 欧洲在线观看在线视频吗 | 亚洲综合色婷婷中文字幕 | 四虎国产精品免费观看 | 天天澡天天摸天天爽免费 | 国产在线美女 | 国产一级做a爰片久久毛片99 | 护士精品一区二区三区 | 爽天天天天天天天 | 久久a热6| 2018狠狠操 | 欧美亚洲激情 | 国产91精选在线观看麻豆 | 亚洲国产综合精品中文字幕 | 九一国产精品 | 2022免费国产精品福利在线 | 天天综合色天天综合网 | 日韩精品一区二区三区视频网 | 欧洲色播| 黄色高清视频在线观看 | 久久久91| 91麻豆精品国产综合久久久 | 九九久久国产 | 99综合视频| 亚洲精品美女久久久久网站 | 久久免费视频一区 | 一级做α爱过程免费视频 |