<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      《JavaScript高級程序設計》閱讀筆記(二十):錯誤處理

      一、錯誤分類

        1、語法錯誤:也稱解析錯誤,發生在傳統語言的編譯時,在JavaScript中發生在解釋時。這些錯誤是由代碼中的意外字符直接引起的,然后就不能直接編譯/解釋。發生語法錯誤時,就不能繼續執行代碼。在JavaScript中,只有在同一個線程中的代碼會受語法錯誤的影響。在其他線程中的代碼和其他外部引用的文件中的代碼,如果不依賴于包含錯誤的代碼,則可以繼續執行。

        2、運行時錯誤:也稱為異常(exception,在編譯期/解釋器后)。此時,問題并不出在代碼的語法上,而是,嘗試完成的一個操作,在某些情況下是非法的。異常只影響發生的線程,其他JavaScript線程即可繼續正常的執行。

      二、錯誤處理

        JavaScript提供了兩種處理錯誤的方式:BOM中的onerror事件處理函數方式和ECMAScript中的try...catch方式。

        1、onerror事件處理函數

        它是第一個用來協助JavaScript處理錯誤的機制。頁面上出現異常時,error事件便在window對象上觸發。例如:

      <html>
          <head>
                 <title>onerror Example</title>
                 <script type="text/javascript">
                        window.onerror = function() {
                              alert("發生錯誤!");
                         }
                 </script>
             </head>
             <body onload="nonExistentFunction()">
             </body>
      </html>

        在上述代碼中,在頁面載入時嘗試調用不存在的函數,此時會引發一個異常。彈出“發生錯誤”的錯誤信息。但是,瀏覽器的錯誤信息也顯示出來了,如何在瀏覽器上隱藏它呢,只需onerror方法返回一個true即可。

      <script type="text/javascript">
           window.onerror = function() {
                 alert(“發生錯誤!”);
                 return true;
            }
      </script>

        1.1 取出錯誤信息

        onerror處理函數提供了三種信息來確定錯誤確切的性質:

        i) 錯誤信息——對于給定錯誤,瀏覽器會顯示同樣的信息

        ii) URL——在哪個文件中發生了錯誤

        iii) 行號——給定URL中發生錯誤的行號。

      window.onerror = function(sMessage, sUrl, iLine) {
            alert("發生錯誤!\n" + sMessage + "\nURL:" + sUrl + "\nLine Number:" + iLine);
            return true;
      }

        1.2 圖像載入錯誤

        window對象并非唯一支持onerror事件處理函數的對象,它對圖像對象也提供支持。當一個圖像由于文件不存在等原因未能成功載入時,error事件便在這個圖像上觸發。例如:

      <img src="noexist.gif" onerror="alert('載入圖片時發生錯誤')"/>

        上例直接在HTML中分配onerror事件處理函數。因為noexist.gif不存在,所以會彈出警告框提示用戶。當然也可以通過腳本來分配事件處理函數,在設置圖像的src特性前,必須等待頁面完全載入,例如:

      <html>
          <head>
              <title>Image錯誤測試</title>
              <script type="text/javascript">
                  function handleLoad() {
                      document.images[0].onerror = function() {
                          alert("載入圖片時發生錯誤!");
                      };
      
                      document.images[0].src = "amigo.jpg";
                  }
             </script>
         </head>
         <body onload="handleLoad()">
             <img/>
          <body>
      </html>

        注意:與window對象的onerror事件處理函數不同,imageonerror事件沒有任何關于額外信息的參數。

        1.3處理語法錯誤

        onerror事件處理函數不僅可以處理異常,它還能處理語法錯誤,也只有它才能處理。

        首先,事件處理函數必須是頁面中第一個出現的代碼,因為如果語法錯誤出現在設置事件處理函數之前出現,事件處理函數就沒有用了。記住,語法錯誤會完全停止代碼的執行。例如:

      <html>
      <head>
          <title>onError Example</title>
          <script type="text/javascript">
              alert("Syntax error.";
              window.onerror = function (sMessage, sUrl, iLine){
                  alert("An error occurrred:\n" + sMessage + "\nURL:" + sUrl + "\nLine Number:" + iLine );
                  return true;
              }
          </script>
      </head>
      <body onload="nonExistentFunction()">
      </body>
      </html>

        因為突出顯示的那一行代碼(里面有錯誤語法)在分配onerror事件處理函數之前就出現了,所以瀏覽器直接報告這個錯誤。在錯誤之后的代碼就不再被解釋(因為這個線程已經退出了),所以 load 事件解發時調用 nonExistentFunction() ,瀏覽器也會報這個錯誤。書中說如果重寫這個頁面,將 onerror 事件處理函數的分配放在語法錯誤之前,那么會出現兩個警告框:一個顯示語法錯誤,另一個顯示異常。但我測試的結果還是一樣的報兩個錯誤,并不顯示onerror事件中的信息。

        使用onerror事件處理函數的主要的問題是,它是BOM的一部分,所以,沒有任何標準能控制它的行為。因此,不同的瀏覽器使用這個事件處理錯誤的方式有明顯的不同,eg,在IE中發生error事件時,正常的代碼會繼續執行,所有的變量和數據都保留下來,并可通過onerror事件處理函數訪問。在Mozilla中,正常的代碼執行都會結束,同時所有的錯誤發生之前的變量和數據都被銷毀。

        2、try...catch方式

        ECMPScript第三版,引入了try…catch語句。基本語法如下:

      try{
          //code
          [break;]
      } catch ([exception]) {
          //code
          [break;]
      } [finally{
          //code
      }]

        例如:

      try {
              window.openFile1();
              alert("成功調用openFile1方法");
      } catch (exception) {
              alert("發生異常!");
      } finally {
              alert("try..catch測試結束!");
      }

        與Java不同,ECMAScript標準在try…catch語句中只能有一個catch語句,因為JavaScript是弱類型的語言,沒辦法指明catch子句中異常的特定類型。不管錯誤是什么類型,都由同一個catch語句處理。Mozilla對其進行了擴展,可加多個catch語句,但因為只有 Mozilla 可以使用,因此不推薦使用。

        finally用于包含無論是否有異常發生都要執行的代碼,這對關閉打開的鏈接和釋放資源很有用。

        2.1 嵌套 try...catch 語句

        在 try...catch 語句中的 catch 子句中,也會發生錯誤。此時,就可以使用嵌套的 try...catch 語句。示例:

      try {
          eval("a ++ b");
      } catch(oException) {
          alert("發生錯誤!");
          try {
            var aError = new Array(1000000000000000000000000000000000000000);
          } catch(exception) {
              alert("在catch子句中發生錯誤!");
          }
      } finally{
             alert("已完成")
      }

        2.2 Error對象

        發生錯誤時,JavaScript有個Error基類用于拋出。它有兩個特性:

        i)name——表示錯誤類型的字符串

        ii)message——實際的錯誤信息

        Error對象的name對應于它的類,可以是如下值之一:

        EvalError:錯誤發生在eval()函數中;

        RangeError:數字值超出JavaScript可表示的范圍;

        ReferenceError:使用了非法的引用;

        SyntaxError:在eval()函數調用中發生了語法錯誤,其他的愈發錯誤由瀏覽器報告,無法通過try…catch處理;

        TypeError:變量的類型不是預期所需的;

        URIError:在encodeURI或decodeURI函數發生了錯誤。

        2.3 判斷錯誤類型

        盡管每個 try...catch 語句中只能有一個catch子句,但判斷拋出的錯誤類型方法主要有兩種。第一種使用 Error 對象的 name 特性:

      try {
          eval("a ++ b");
      } catch(oException) {
          if (oException.name = "SyntaxError") {
              alert("發生SyntaxError!");
          } else {
              alert("發生其他錯誤!");
          }
      }

        第二種使用 instanceof 操作符,并使用不同錯誤的類名:

      try {
          eval("a ++ b");
      } catch(oException) {
          if (oException instanceof SyntaxError) {
              alert("發生SyntaxError!");
          } else {
              alert("發生其他錯誤!");
          }
      }

        2.4 拋出異常

        ECMAScript第三版引入,用于有目的的拋出異常,拋出的錯誤對象可為字符串、數字、布爾值或實際的對象,也可以拋出Error對象(其構造函數只有一個函數,即錯誤信息)。如:

      throw new Error(“錯誤產生!”);

        開發人員拋出的錯誤和由瀏覽器自身拋出的錯誤都在 try...catch 中捕獲。例如:

      function addTwoNumber(a, b) {
          if (arguments.length < 2) {
              throw new Error("需要傳入兩個數字!");
          }
      }
      
      try {
           result = addTwoNumber(90);
      } catch(oException) {
          if (oException instanceof SyntaxError) {
               alert("SyntaxError:" + oException.message);
          } else if (oException instanceof Error){
               alert(oException.message);
          }
      }

      三、調試技巧

        現在的瀏覽器大多都自帶了調試工具,大多數情況下已經夠用了,另外IE下還可以用IETest,FireFox下還可以用FireBug。

      posted @ 2012-08-01 08:34  artwl  閱讀(1092)  評論(2)    收藏  舉報

      個人簡介

      var ME = {
      	"name": "土豆/Artwl",
      	"job": "coding",
      	"languages": [
      		"JS", "HTML",
                      "CSS", "jQuery"
      		"MVC",".NET",
      		"設計模式"
      	],
      	"hobby": [
      		"閱讀", "旅游",
      		"音樂", "電影"
      	]
      }
      
      TOP
      主站蜘蛛池模板: 亚洲精品一品二品av| 国产不卡一区二区在线视频| 亚洲精品一区二区三区蜜| 国产系列丝袜熟女精品视频| 国产盗摄xxxx视频xxxx| 亚洲激情av一区二区三区| 一区二区三区国产不卡| 亚洲香蕉伊综合在人在线| 国精品91人妻无码一区二区三区| 国产亚洲精品岁国产精品| 亚洲成AV人片在线观高清| 亚洲国产精品综合久久20| 又黄又爽又色的少妇毛片| 精品一区二区三区在线播放视频| 开远市| 亚洲国产欧美在线人成aaaa| 国产精品不卡一二三区| 亚洲日韩日本中文在线| 日本国产精品第一页久久| 精品无码久久久久久尤物| 么公的好大好硬好深好爽视频 | 久久av色欲av久久蜜桃网| 国产乱子伦视频在线播放| 成人欧美日韩一区二区三区| 国产日韩精品欧美一区灰 | 久操热在线视频免费观看| 免费午夜无码片在线观看影院| 国产99视频精品免费视频76| 精品国产人妻一区二区三区久久| 永顺县| 精品久久久久久无码不卡| 狠狠婷婷色五月中文字幕| 欧洲无码一区二区三区在线观看 | 97人人添人澡人人爽超碰| 日韩高清砖码一二区在线| 国产成人亚洲无码淙合青草| 国产精品久久久福利| 亚洲中文字幕综合网在线| 毛多水多高潮高清视频| 好男人日本社区www| 黄又色又污又爽又高潮|