欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript容錯(cuò)例外處理第2/2頁(yè)

 更新時(shí)間:2008年06月08日 20:03:45   作者:  
程序開發(fā)中,編程人員經(jīng)常要面對(duì)的是如何編寫代碼來(lái)響應(yīng)錯(cuò)誤事件的發(fā)生,即例外處理(exception handlers)。

六、定制例外信息

  上述的六種Error類型基本上覆蓋了腳本程序運(yùn)行時(shí)所可能發(fā)生的錯(cuò)誤。除了這些類型以外,我們還可以使用Error構(gòu)造器來(lái)自定義例外類型,其語(yǔ)法如下:

  myError = new Error(msg)
  其中msg參數(shù)表示所定義的新例外的message屬性值。同時(shí),我們還可以創(chuàng)建新的對(duì)象類型以作為Error的子類型:

  function MyError(msg) {
  this.name = "MyError"
  this.message = msg
  }
  MyError.prototype = new Error;

  然后,我們就可以創(chuàng)建自定義錯(cuò)誤子類的實(shí)例:
  myError = new MyError("My error message")

  七、觸發(fā)例外

  創(chuàng)建一個(gè)Error對(duì)象后,就可以使用throw語(yǔ)句來(lái)觸發(fā)相應(yīng)的例外。Throw的語(yǔ)法如下:
  throw errObj

  errObj必須是一個(gè)Error對(duì)象或者Error的子類型。在try塊代碼中觸發(fā)一個(gè)例外后,控制將直接轉(zhuǎn)入catch塊。

  下面的代碼中,在try塊中觸發(fā)了一個(gè)例外,設(shè)置例外信息為“oops”,然后控制轉(zhuǎn)移到catch塊: 

  var s
  try {
    s = "one "
    throw new Error("oops")
    s += "two"
  } catch(err) {
    s += err.message
  }
  s += " three"
  alert(s)

  運(yùn)行后出現(xiàn)如下的提示框: 


  編寫代碼來(lái)觸發(fā)例外的優(yōu)點(diǎn)很多,比如有利于自定義錯(cuò)誤類型,快速轉(zhuǎn)入catch塊執(zhí)行,以及下面要介紹的在嵌套例外中將錯(cuò)誤傳遞到外層。


八、嵌套例外處理


  JavaScript支持多層次的嵌套例外處理。一般情況下,我們可以在內(nèi)部例外處理的catch代碼塊中捕捉并處理錯(cuò)誤,然后再次觸發(fā)例外,這樣就可進(jìn)一步在外部例外處理的catch代碼塊中做更加深入的處理。下面來(lái)看看一個(gè)嵌套例外處理的例子: 

  var inner;
  var outer;
  try {
    document.writeln("Beginning outer try block, no exceptions yet");
  try{
    document.writeln("Beginning inner try block, no exceptions yet");
    // 生成一個(gè)引用錯(cuò)誤
    document.writeln(undefinedVariable)
    document.writeln("Finished inner try block with no exceptions");
  } catch(inner) {
  // 內(nèi)部例外處理
    document.writeln("Exception caught, beginning inner catch block");
    document.writeln("Error type: " + inner.name);
    document.writeln("Error message: " + inner.message);
    throw inner;
    document.writeln("No exceptions thrown in inner catch block");
  } finally {
    document.writeln("Executing inner finally block");
  }
    document.writeln("Finished outer try block with no exceptions");
  } catch(outer) {
    // 外部例外處理
    document.writeln("Exception caught, beginning outer catch block");
    document.writeln("Error type: " + outer.name);
    document.writeln("Error message: " + outer.message);
  } finally {
    document.writeln("Executing outer finally block");
  }


  執(zhí)行后的輸出結(jié)果如下:


  Beginning outer try block, no exceptions yet
  Beginning inner try block, no exceptions yet
  Exception caught, beginning inner catch block
  Error type: ReferenceError
  Error message: undefinedVariable is not defined
  Executing inner finally block
  Exception caught, beginning outer catch block
  Error type: ReferenceError
  Error message: undefinedVariable is not defined
  Executing outer finally block

  嵌套例外處理的好處在于使我們能夠很好地分階段處理錯(cuò)誤,內(nèi)部例外處理可以負(fù)責(zé)解決由錯(cuò)誤引發(fā)的腳本代碼問(wèn)題,外部例外處理則用于負(fù)責(zé)提供給用戶的反饋信息或者對(duì)例外信息進(jìn)行日志記錄。


  九、結(jié)語(yǔ)

  本文詳細(xì)討論了JavaScript語(yǔ)言的一個(gè)很重要的特征“例外處理”,Web開發(fā)人員應(yīng)該很好地掌握它并在實(shí)際應(yīng)用中靈活處理,從而使包含腳本代碼的HTML頁(yè)面真正地不出例外、善解人意。

相關(guān)文章

  • JavaScript設(shè)計(jì)模式之單件模式介紹

    JavaScript設(shè)計(jì)模式之單件模式介紹

    這篇文章主要介紹了JavaScript設(shè)計(jì)模式之單件模式介紹,單件模式,就是靜態(tài)化的訪問(wèn)中已經(jīng)實(shí)例化的對(duì)象,這個(gè)對(duì)象只能通過(guò)一個(gè)唯一的入口訪問(wèn),已經(jīng)實(shí)例或待實(shí)例化的對(duì)象,需要的朋友可以參考下
    2014-12-12
  • JavaScript實(shí)現(xiàn)拖拽元素對(duì)齊到網(wǎng)格(每次移動(dòng)固定距離)

    JavaScript實(shí)現(xiàn)拖拽元素對(duì)齊到網(wǎng)格(每次移動(dòng)固定距離)

    最近在做一個(gè)拖拽元素的附加功能,就是對(duì)齊到網(wǎng)格,實(shí)際上就是確定好元素的初始位置,然后拖拽元素時(shí),每次移動(dòng)固定的距離。讓元素都可以在網(wǎng)格內(nèi)對(duì)齊
    2016-11-11
  • Google AJAX 搜索 API實(shí)現(xiàn)代碼

    Google AJAX 搜索 API實(shí)現(xiàn)代碼

    Google AJAX 搜索 API實(shí)現(xiàn)代碼,需要的朋友可以參考下。
    2010-11-11
  • 微信小程序自定義導(dǎo)航欄

    微信小程序自定義導(dǎo)航欄

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義導(dǎo)航欄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • JS中l(wèi)et的基本用法舉例

    JS中l(wèi)et的基本用法舉例

    ES6新增了let命令,用來(lái)聲明變量,它的用法類似于var,但是所聲明的變量,只在let命令所在的代碼塊內(nèi)有效,下面這篇文章主要給大家介紹了關(guān)于JS中l(wèi)et的基本用法,需要的朋友可以參考下
    2023-01-01
  • JavaScript對(duì)象合并實(shí)現(xiàn)步驟介紹

    JavaScript對(duì)象合并實(shí)現(xiàn)步驟介紹

    這篇文章主要介紹了JavaScript對(duì)象合并實(shí)現(xiàn)步驟,為什么要合并?這是我在重構(gòu)代碼的時(shí)候的一個(gè)需求。簡(jiǎn)單來(lái)說(shuō),我會(huì)有若干個(gè)對(duì)象需要合并為一個(gè)對(duì)象。而這些對(duì)象為兩層,如果直接展開或者賦值會(huì)涉及到深拷貝
    2023-01-01
  • js 獲取radio按鈕值的實(shí)例

    js 獲取radio按鈕值的實(shí)例

    這篇文章介紹了js 獲取radio按鈕值的實(shí)例,有需要的朋友可以參考一下
    2013-08-08
  • JavaScript的基礎(chǔ)語(yǔ)法和數(shù)據(jù)類型詳解

    JavaScript的基礎(chǔ)語(yǔ)法和數(shù)據(jù)類型詳解

    這篇文章主要介紹了JavaScript的基礎(chǔ)語(yǔ)法和數(shù)據(jù)類型,保姆級(jí)的詳細(xì)教程,萬(wàn)字長(zhǎng)文詳細(xì)的列出了JavaScript的各種語(yǔ)法,建議收藏系列,希望可以有所幫助
    2021-09-09
  • js window.onload 加載多個(gè)函數(shù)和追加函數(shù)詳解

    js window.onload 加載多個(gè)函數(shù)和追加函數(shù)詳解

    本篇文章主要是對(duì)js window.onload 加載多個(gè)函數(shù)和追加函數(shù)進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-01-01
  • JavaScript中計(jì)算網(wǎng)頁(yè)中某個(gè)元素的位置

    JavaScript中計(jì)算網(wǎng)頁(yè)中某個(gè)元素的位置

    這篇文章主要介紹了JavaScript中計(jì)算網(wǎng)頁(yè)中某個(gè)元素的位置,本文先是講解了一些必要的知識(shí)和實(shí)現(xiàn)難點(diǎn),然后給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2015-06-06

最新評(píng)論