जावास्क्रिप्ट - त्रुटियां और अपवाद हैंडलिंग

प्रोग्रामिंग में तीन प्रकार की त्रुटियां हैं: (ए) सिंटेक्स एरर्स, (बी) रनटाइम एरर्स और (सी) लॉजिकल एरर्स।

सिंटेक्स त्रुटियां

सिंटैक्स त्रुटियां, जिन्हें भी कहा जाता है parsing errors, पारंपरिक प्रोग्रामिंग भाषाओं में संकलन समय और जावास्क्रिप्ट में समय की व्याख्या करने पर।

उदाहरण के लिए, निम्न पंक्ति एक सिंटैक्स त्रुटि का कारण बनती है क्योंकि यह एक बंद कोष्ठक को याद कर रही है।

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

जब कोई सिंटैक्स त्रुटि जावास्क्रिप्ट में होती है, तो सिंटैक्स त्रुटि के रूप में एक ही थ्रेड के भीतर मौजूद कोड प्रभावित होता है और अन्य थ्रेड्स में कोड के बाकी हिस्सों को निष्पादित किया जाता है, यह मानते हुए कि उनमें से कुछ भी कोड नहीं है, जिसमें त्रुटि है।

रनटाइम त्रुटियां

रनटाइम त्रुटियों को भी कहा जाता है exceptions, निष्पादन के दौरान (संकलन / व्याख्या के बाद)।

उदाहरण के लिए, निम्न पंक्ति एक रनटाइम त्रुटि का कारण बनती है क्योंकि यहां सिंटैक्स सही है, लेकिन रनटाइम पर, यह एक ऐसी विधि को कॉल करने का प्रयास कर रहा है जो मौजूद नहीं है।

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

अपवाद उस धागे को भी प्रभावित करते हैं जिसमें वे होते हैं, जिससे अन्य जावास्क्रिप्ट धागे सामान्य निष्पादन को जारी रखने की अनुमति देते हैं।

तार्किक त्रुटियां

तर्क त्रुटियों को ट्रैक करने के लिए त्रुटियों का सबसे कठिन प्रकार हो सकता है। ये त्रुटियाँ सिंटैक्स या रनटाइम त्रुटि का परिणाम नहीं हैं। इसके बजाय, वे तब होते हैं जब आप तर्क में एक गलती करते हैं जो आपकी स्क्रिप्ट को ड्राइव करता है और आपको अपेक्षित परिणाम नहीं मिलता है।

आप उन त्रुटियों को नहीं पकड़ सकते, क्योंकि यह आपकी व्यावसायिक आवश्यकता पर निर्भर करता है कि आप अपने कार्यक्रम में किस प्रकार का तर्क रखना चाहते हैं।

कोशिश ... पकड़ ... अंत में बयान

जावास्क्रिप्ट के नवीनतम संस्करणों ने अपवाद हैंडलिंग क्षमताओं को जोड़ा। जावास्क्रिप्ट लागू करता है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-

<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>

उत्पादन

आप उपयोग कर सकते हैं finallyब्लॉक जो हमेशा कोशिश / पकड़ने के बाद बिना शर्त निष्पादित करेगा। यहाँ एक उदाहरण है।

<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ईवेंट हैंडलर जावास्क्रिप्ट में त्रुटि से निपटने की सुविधा प्रदान करने वाला पहला फीचर था। 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 टैग्स के साथ।