JavaScript-오류 및 예외 처리

프로그래밍 오류에는 (a) 구문 오류, (b) 런타임 오류 및 (c) 논리적 오류의 세 가지 유형이 있습니다.

구문 오류

구문 오류 (라고도 함) parsing errors, 전통적인 프로그래밍 언어에서는 컴파일 타임에 발생하고 JavaScript에서는 인터프리터 타임에 발생합니다.

예를 들어 다음 줄은 닫는 괄호가 없기 때문에 구문 오류가 발생합니다.

<script type = "text/javascript">
   <!--
      window.print(;
   //-->
</script>

JavaScript에서 구문 오류가 발생하면 구문 오류와 동일한 스레드에 포함 된 코드 만 영향을 받고 다른 스레드의 나머지 코드는 오류가 포함 된 코드에 의존하지 않는다고 가정하여 실행됩니다.

런타임 오류

런타임 오류 (라고도 함) exceptions, 실행 중에 발생합니다 (컴파일 / 해석 후).

예를 들어 다음 줄은 구문이 정확하기 때문에 런타임 오류가 발생하지만 런타임에는 존재하지 않는 메서드를 호출하려고합니다.

<script type = "text/javascript">
   <!--
      window.printme();
   //-->
</script>

예외는 발생하는 스레드에도 영향을 미치므로 다른 JavaScript 스레드가 정상 실행을 계속할 수 있습니다.

논리적 오류

논리 오류는 추적하기 가장 어려운 유형의 오류 일 수 있습니다. 이러한 오류는 구문 또는 런타임 오류의 결과가 아닙니다. 대신 스크립트를 구동하는 논리에 실수를하여 예상 한 결과를 얻지 못할 때 발생합니다.

이러한 오류는 비즈니스 요구 사항에 따라 프로그램에 넣을 논리 유형에 따라 다르기 때문에 포착 할 수 없습니다.

try ... catch ... finally 문

최신 버전의 JavaScript에는 예외 처리 기능이 추가되었습니다. JavaScript는try...catch...finally 구성뿐만 아니라 throw 연산자를 사용하여 예외를 처리합니다.

당신은 할 수 있습니다 catch 프로그래머 생성 및 runtime 예외이지만 할 수 없습니다 catch 자바 스크립트 구문 오류.

여기 있습니다 try...catch...finally 블록 구문-

<script type = "text/javascript">
   <!--
      try {
         // Code to run
         [break;]
      } 
      
      catch ( e ) {
         // Code to run if an exception occurs
         [break;]
      }
      
      [ finally {
         // Code that is always executed regardless of 
         // an exception occurring
      }]
   //-->
</script>

그만큼 try 블록 뒤에 정확히 하나가 와야합니다. catch 블록 또는 하나 finally블록 (또는 둘 중 하나). 예외가 발생하는 경우try 블록, 예외는 e 그리고 catch블록이 실행됩니다. 선택 사항finally 블록은 try / catch 후에 무조건 실행됩니다.

다음은 예외를 발생시키는 존재하지 않는 함수를 호출하려는 예입니다. 그것이 어떻게 작동하는지 보자try...catch

<html>
   <head>      
      <script type = "text/javascript">
         <!--
            function myFunc() {
               var a = 100;
               alert("Value of variable a is : " + a );
            }
         //-->
      </script>      
   </head>
   
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>      
   </body>
</html>

산출

이제 다음을 사용하여이 예외를 포착 해 보겠습니다. try...catch사용자 친화적 인 메시지를 표시합니다. 사용자로부터이 오류를 숨기려면이 메시지를 표시하지 않을 수도 있습니다.

<html>
   <head>
      
      <script type = "text/javascript">
         <!--
            function myFunc() {
               var a = 100;
               try {
                  alert("Value of variable a is : " + a );
               } 
               catch ( e ) {
                  alert("Error: " + e.description );
               }
            }
         //-->
      </script>
      
   </head>
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>
      
   </body>
</html>

산출

당신이 사용할 수있는 finallytry / catch 이후에 항상 무조건 실행되는 블록. 여기에 예가 있습니다.

<html>
   <head>
      
      <script type = "text/javascript">
         <!--
            function myFunc() {
               var a = 100;
               
               try {
                  alert("Value of variable a is : " + a );
               }
               catch ( e ) {
                  alert("Error: " + e.description );
               }
               finally {
                  alert("Finally block will always execute!" );
               }
            }
         //-->
      </script>
      
   </head>
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>
      
   </body>
</html>

산출

던지기 진술

당신이 사용할 수있는 throw내장 예외 또는 사용자 정의 된 예외를 발생시키는 문. 나중에 이러한 예외를 캡처하고 적절한 조치를 취할 수 있습니다.

다음 예제는 사용 방법을 보여줍니다. throw 성명서.

<html>
   <head>
      
      <script type = "text/javascript">
         <!--
            function myFunc() {
               var a = 100;
               var b = 0;
               
               try {
                  if ( b == 0 ) {
                     throw( "Divide by zero error." ); 
                  } else {
                     var c = a / b;
                  }
               }
               catch ( e ) {
                  alert("Error: " + e );
               }
            }
         //-->
      </script>
      
   </head>
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>
      
   </body>
</html>

산출

문자열, 정수, 부울 또는 객체를 사용하여 한 함수에서 예외를 발생시킨 다음 위에서했던 것과 동일한 함수 또는 다른 함수에서 예외를 캡처 할 수 있습니다. try...catch 블록.

onerror () 메서드

그만큼 onerror이벤트 핸들러는 JavaScript에서 오류 처리를 용이하게하는 첫 번째 기능입니다. 그만큼error 페이지에서 예외가 발생할 때마다 창 개체에서 이벤트가 시작됩니다.

<html>
   <head>
      
      <script type = "text/javascript">
         <!--
            window.onerror = function () {
               alert("An error occurred.");
            }
         //-->
      </script>
      
   </head>
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>
      
   </body>
</html>

산출

그만큼 onerror 이벤트 핸들러는 오류의 정확한 특성을 식별하기 위해 세 가지 정보를 제공합니다.

  • Error message − 브라우저가 주어진 오류에 대해 표시하는 것과 동일한 메시지

  • URL − 오류가 발생한 파일

  • Line number− 오류를 일으킨 주어진 URL의 줄 번호

다음은이 정보를 추출하는 방법을 보여주는 예입니다.

<html>
   <head>
   
      <script type = "text/javascript">
         <!--
            window.onerror = function (msg, url, line) {
               alert("Message : " + msg );
               alert("url : " + url );
               alert("Line number : " + line );
            }
         //-->
      </script>
      
   </head>
   <body>
      <p>Click the following to see the result:</p>
      
      <form>
         <input type = "button" value = "Click Me" onclick = "myFunc();" />
      </form>
      
   </body>
</html>

산출

추출 된 정보를 더 낫다고 생각하는 방식으로 표시 할 수 있습니다.

당신은 사용할 수 있습니다 onerror 아래 그림과 같이 이미지 로딩에 문제가있는 경우 오류 메시지를 표시합니다.

<img src="myimage.gif" onerror="alert('An error occurred loading the image.')" />

당신이 사용할 수있는 onerror 오류 발생시 적절한 메시지를 표시하는 많은 HTML 태그가 있습니다.