溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JavaScript例外處理技術(shù)怎么使用

發(fā)布時間:2021-12-03 16:08:19 來源:億速云 閱讀:148 作者:iii 欄目:編程語言

本篇內(nèi)容介紹了“JavaScript例外處理技術(shù)怎么使用”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

  一、什么是例外處理

  當(dāng)Javascript程序在運(yùn)行中發(fā)生了諸如數(shù)組索引越界、類型不匹配或者語法錯誤時,Javascript解釋器就會引發(fā)例外處理。 ECMAscript定義了六種類型的錯誤,除此之外,我們可以使用Error對象和throw語句來創(chuàng)建并引發(fā)自定義的例外處理信息。

  二、例外處理技術(shù)的優(yōu)點(diǎn)

  通過運(yùn)用例外處理技術(shù),我們可以實現(xiàn)用結(jié)構(gòu)化的方式來響應(yīng)錯誤事件的發(fā)生,讓例外處理代碼與正常腳本代碼科學(xué)分離,最終使我們能夠集中精力編寫完成主要功能的核心程序。

  三、使用 try…catch…finally 執(zhí)行例外處理

  在Javascript中,我們使用try…catch…finally語句來執(zhí)行例外處理,即通過它來捕捉錯誤發(fā)生后導(dǎo)致的例外或者執(zhí)行throw語句產(chǎn)生的例外。它的基本語法如下:
 

 try {
  // 此處是可能產(chǎn)生例外的語句
  } catch(error) {
  // 此處是負(fù)責(zé)例外處理的語句
  } finally {
  // 此處是出口語句
  }

  上述代碼中,try塊中的語句首先被執(zhí)行。如果運(yùn)行中發(fā)生了錯誤,控制就會轉(zhuǎn)移到位于catch塊中語句,其中括號中的error參數(shù)被作為例 外變量傳遞。否則,catch塊的語句被跳過不執(zhí)行。無論是發(fā)生錯誤時catch塊中的語句執(zhí)行完畢,或者沒有發(fā)生錯誤try塊中的語句執(zhí)行完畢,最后將 執(zhí)行finally塊中的語句。

  下面我們來看一個例子:



  我們輸入abc,然后確定,輸出結(jié)果如下:
 

  “開始執(zhí)行try塊語句 ---&gt 還沒有發(fā)生例外 ---&gt 捕捉到例外,開始執(zhí)行catch塊語句 ---&gt 錯誤名稱: TypeError ---&gt 錯誤信息: ‘a(chǎn)bc‘ 未定義 ---&gt 開始執(zhí)行finally塊語句”

  上述例程以try塊語句開始,當(dāng)輸出信息“還沒有發(fā)生例外”后,彈出輸入對話框,要求用戶輸入一個數(shù)值,當(dāng)我們輸入非法的信息"abc"后,就 引發(fā)了一個例外,所以剩下的try塊中的語句將被跳過而開始執(zhí)行catch塊語句。Catch塊開始的err參數(shù)作為這個例外的錯誤對象,它具有name 和message兩個屬性。最后,執(zhí)行finally塊的語句。

  我們看到,由于沒有錯誤發(fā)生,當(dāng)try塊的語句執(zhí)行完畢后,catch塊語句被跳過,出現(xiàn)一個窗口顯示輸入的數(shù)值,最后執(zhí)行了finally塊的語句。

四、try...catch...finally的變形

  try…catch…finally語句有兩種變形應(yīng)用,即try…catch或者try…finally。

  try…catch這種結(jié)構(gòu)最常見,它的執(zhí)行過程是:當(dāng)沒有例外發(fā)生執(zhí)行完畢try塊語句后或者發(fā)生例外執(zhí)行完catch塊語句后,控制將轉(zhuǎn)移到整個try…catch結(jié)構(gòu)后面的語句。請看下面的例子:
 

  try {
    document.writeln("Beginnng the try block")
    document.writeln("No exceptions yet")
  // Create a syntax error
  eval("6 + * 3")
  document.writeln("Finished the try block with no exceptions")
  } catch(err) {
    document.writeln("Exception caught, executing the catch block")
    document.writeln("Error name: " + err.name)
    document.writeln("Error message: " + err.message)
  }
  document.writeln("Executing after the try-catch statement")

  如果是try…finally結(jié)構(gòu),那么當(dāng)發(fā)生例外時,由于沒有catch塊語句來捕捉錯誤,所以最終finally塊的語句也不會被執(zhí)行。因此,這種結(jié)構(gòu)在實際應(yīng)用中很少見。

  五、例外的表現(xiàn)形式:Error對象

  在Javascript,例外是作為Error對象出現(xiàn)的。Error對象有兩個屬性:name屬性表示例外的類型,message屬性表示例外的含義。根據(jù)這些屬性的取值,我們可以決定處理例外的方式,比如:
 

  function evalText() {
  try {
    alert(eval(prompt("Enter Javascript to evaluate:","")))
  } catch(err) {
    if(err.name == "SyntaxError") alert("Invalid expression")
    else alert("Cannot evaluate")
  }
  }

  上面的代碼將對用戶輸入的內(nèi)容進(jìn)行表達(dá)式求值,然后顯示出來。如果在求值過程中發(fā)生了SyntaxErroe類型錯誤,那么就會顯示給用戶“Invalid expression”的信息;否則,用戶得到信息“Cannot evaluate”。

  Error.name的取值一共有六種,如下:

  EvalError:eval()的使用與定義不一致
  RangeError:數(shù)值越界
  ReferenceError:非法或不能識別的引用數(shù)值
  SyntaxError:發(fā)生語法解析錯誤
  TypeError:操作數(shù)類型錯誤
  URIError:URI處理函數(shù)使用不當(dāng)

“JavaScript例外處理技術(shù)怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI