ईएस 6 - डिबगिंग

हर अब और फिर, डेवलपर्स कोडिंग करते समय गलतियां करते हैं। किसी प्रोग्राम या स्क्रिप्ट की गलती को स्क्रिप्ट के रूप में संदर्भित किया जाता हैbug

कीड़े को खोजने और ठीक करने की प्रक्रिया को कहा जाता है debuggingऔर विकास प्रक्रिया का एक सामान्य हिस्सा है। इस अध्याय में उन टूल और तकनीकों को शामिल किया गया है जो आपको डिबगिंग कार्यों में मदद कर सकते हैं।

IE में त्रुटि संदेश

त्रुटियों को ट्रैक करने का सबसे मूल तरीका आपके ब्राउज़र में त्रुटि जानकारी को चालू करना है। डिफ़ॉल्ट रूप से, इंटरनेट एक्सप्लोरर स्थिति पट्टी में एक त्रुटि आइकन दिखाता है जब पृष्ठ पर कोई त्रुटि होती है।

इस आइकन पर डबल-क्लिक करने से आप एक डायलॉग बॉक्स में पहुंच जाते हैं, जो विशिष्ट त्रुटि के बारे में जानकारी देता है।

चूँकि इस आइकन को अनदेखा करना आसान है, जब भी कोई त्रुटि होती है, तो Internet Explorer आपको स्वतः त्रुटि डायलॉग बॉक्स दिखाने का विकल्प देता है।

इस विकल्प को सक्षम करने के लिए, का चयन करें Tools → Internet Options → Advanced tab और फिर अंत में जाँच करेंDisplay a NotificationaboutEvery Script Error"बॉक्स विकल्प जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

फ़ायरफ़ॉक्स या मोज़िला में त्रुटि संदेश

फ़ायरफ़ॉक्स, नेटस्केप, और मोज़िला जैसे अन्य ब्राउज़र एक विशेष विंडो में त्रुटि संदेश भेजते हैं जिन्हें कहा जाता है JavaScript Console या Error Console। कंसोल देखने के लिए, चयन करेंTools → Error Console or Web Development

दुर्भाग्य से, चूंकि ये ब्राउज़र त्रुटि होने पर कोई दृश्य संकेत नहीं देते हैं, इसलिए आपको कंसोल को खुला रखना होगा और त्रुटियों के लिए देखना होगा क्योंकि आपकी स्क्रिप्ट निष्पादित होती है।

त्रुटि सूचनाएँ

कंसोल या इंटरनेट एक्सप्लोरर डायलॉग बॉक्स के माध्यम से दिखाई देने वाली त्रुटि सूचनाएँ सिंटैक्स और रनटाइम त्रुटियों दोनों का परिणाम हैं। इन त्रुटि सूचनाओं में वह पंक्ति संख्या शामिल होती है जिस पर त्रुटि हुई।

यदि आप फ़ायरफ़ॉक्स का उपयोग कर रहे हैं, तो आप त्रुटि कंसोल में उपलब्ध त्रुटि पर क्लिक कर सकते हैं जिसमें त्रुटि होने वाली स्क्रिप्ट में सटीक लाइन पर जा सकते हैं।

एक स्क्रिप्ट डिबगिंग

आपके जावास्क्रिप्ट को डीबग करने के विभिन्न तरीके हैं। इसके कुछ तरीके निम्नलिखित हैं।

एक जावास्क्रिप्ट वैध का प्रयोग करें

अजीब बग के लिए अपने जावास्क्रिप्ट कोड को जांचने का एक तरीका यह है कि इसे एक प्रोग्राम के माध्यम से चलाया जाए जो यह सुनिश्चित करता है कि यह मान्य है और यह भाषा के आधिकारिक वाक्यविन्यास नियमों का पालन करता है। इन कार्यक्रमों को कहा जाता हैvalidating parsers या संक्षिप्त के लिए सिर्फ सत्यापनकर्ता, और अक्सर वाणिज्यिक HTML और जावास्क्रिप्ट संपादकों के साथ आते हैं।

जावास्क्रिप्ट के लिए सबसे सुविधाजनक सत्यापनकर्ता डगलस क्रॉकफोर्ड की जावास्क्रिप्ट लिंट है, जो डगलस क्रॉकफोर्ड के जावास्क्रिप्ट लिंट पर मुफ्त में उपलब्ध है।

बस वेब पेज पर जाएँ, अपने जावास्क्रिप्ट (केवल जावास्क्रिप्ट) कोड को दिए गए पाठ क्षेत्र में पेस्ट करें, और क्लिक करें jslintबटन। यह प्रोग्राम आपके जावास्क्रिप्ट कोड के माध्यम से पार्स करेगा, यह सुनिश्चित करते हुए कि सभी चर और फ़ंक्शन परिभाषाएँ सही सिंटैक्स का पालन करती हैं। यह जावास्क्रिप्ट स्टेटमेंट की भी जांच करेगा, जैसे कि यदि और जबकि, यह सुनिश्चित करने के लिए कि वे भी सही प्रारूप का पालन करते हैं।

अपने प्रोग्राम में डिबगिंग कोड जोड़ें

आप उपयोग कर सकते हैं alert() या document.write()आपके प्रोग्राम में आपके कोड को डीबग करने के तरीके। उदाहरण के लिए, आप कुछ इस प्रकार लिख सकते हैं -

var debugging = true; var whichImage = "widget"; 
if( debugging )  
   alert( "Calls swapImage() with argument: " + whichImage ); 
   var swapStatus = swapImage( whichImage ); 
if( debugging )  
alert( "Exits swapImage() with swapStatus=" + swapStatus );

अलर्ट की सामग्री और क्रम की जांच करके (जैसे वे दिखाई देते हैं, आप अपने कार्यक्रम के स्वास्थ्य की जांच बहुत आसानी से कर सकते हैं।

एक जावास्क्रिप्ट डीबगर का उपयोग करें

debuggerएक प्रोग्रामर है जो प्रोग्रामर के नियंत्रण में स्क्रिप्ट निष्पादन के सभी पहलुओं को रखता है। डीबगर्स एक इंटरफ़ेस के माध्यम से स्क्रिप्ट की स्थिति पर ठीक-ठीक नियंत्रण प्रदान करते हैं जो आपको मूल्यों के परीक्षण और सेट करने के साथ-साथ निष्पादन के प्रवाह को नियंत्रित करने की अनुमति देता है।

एक बार जब एक स्क्रिप्ट को डिबगर में लोड किया जाता है, तो इसे एक बार में एक लाइन चलाया जा सकता है या कुछ ब्रेकपॉइंट पर रुकने का निर्देश दिया जा सकता है। एक बार जब निष्पादन रोक दिया जाता है, तो प्रोग्रामर स्क्रिप्ट और उसके चर की स्थिति की जांच कर सकता है ताकि यह निर्धारित किया जा सके कि कुछ गड़बड़ है। आप उनके मूल्यों में बदलाव के लिए चर भी देख सकते हैं।

मोज़िला और नेटस्केप ब्राउज़र दोनों के लिए मोज़िला जावास्क्रिप्ट डीबगर (कोड-नाम वेंकमैन) का नवीनतम संस्करण - www.hacksrus.com/~ginda/venkman से डाउनलोड किया जा सकता है ।

डेवलपर्स के लिए उपयोगी टिप्स

अपनी स्क्रिप्ट में त्रुटियों की संख्या को कम करने और डिबगिंग प्रक्रिया को सरल बनाने के लिए आप निम्नलिखित सुझावों को ध्यान में रख सकते हैं -

  • टिप्पणियों का भरपूर उपयोग करें। टिप्पणियां आपको यह समझाने में सक्षम करती हैं कि आपने स्क्रिप्ट को जिस तरह से लिखा था और विशेष रूप से कोड के कठिन वर्गों को समझाने के लिए लिखा था।

  • अपने कोड को पढ़ने में आसान बनाने के लिए हमेशा इंडेंटेशन का उपयोग करें। इंडेंटिंग स्टेटमेंट आपके लिए शुरुआत और समाप्ति टैग, घुंघराले ब्रेस और अन्य HTML और स्क्रिप्ट तत्वों से मेल खाना आसान बनाता है।

  • मॉड्यूलर कोड लिखें। जब भी संभव हो, अपने बयानों को फ़ंक्शन में समूहित करें। फ़ंक्शंस आपको समूह से संबंधित कथन देते हैं, और न्यूनतम प्रयास के साथ कोड के पुन: उपयोग भागों का परीक्षण करते हैं।

  • जिस तरह से आप अपने चर और कार्यों का नाम देते हैं, उसके अनुरूप बनें। उन नामों का उपयोग करने का प्रयास करें जो लंबे समय तक सार्थक रहें और जो चर या फ़ंक्शन के उद्देश्य का वर्णन करें।

  • चर और कार्यों का नामकरण करते समय लगातार सिंटैक्स का उपयोग करें। दूसरे शब्दों में, उन्हें सभी लोअरकेस या सभी अपरकेस रखें; यदि आप कैमल-बैक नोटेशन पसंद करते हैं, तो इसका लगातार उपयोग करें।

  • मॉड्यूलर फैशन में लंबी स्क्रिप्ट का परीक्षण करें। दूसरे शब्दों में, इसके किसी भी हिस्से का परीक्षण करने से पहले पूरी स्क्रिप्ट लिखने की कोशिश न करें। एक टुकड़ा लिखें और इसे कोड के अगले भाग को जोड़ने से पहले काम करने के लिए प्राप्त करें।

  • वर्णनात्मक चर और फ़ंक्शन नामों का उपयोग करें और एकल वर्ण नामों का उपयोग करने से बचें।

  • अपने उद्धरण चिह्न देखें। याद रखें कि उद्धरण चिह्नों का उपयोग तारों के चारों ओर जोड़े में किया जाता है और दोनों उद्धरण चिह्न एक ही शैली (या तो एकल या दोहरे) के होने चाहिए।

  • अपने बराबर के संकेत देखें। तुलना उद्देश्य के लिए आपको एक भी = का उपयोग नहीं करना चाहिए।

  • स्पष्ट रूप से चर का स्पष्ट रूप से उपयोग करें var कीवर्ड।

Node.js के साथ डिबगिंग

Node.js में एक पूर्ण विशेषताओं वाली डीबगिंग सुविधा शामिल है। इसका उपयोग करने के लिए, Node.js को डीबग तर्क के साथ शुरू करें और स्क्रिप्ट को डीबग करने के लिए पथ के साथ।

node debug test.js

एक संकेत है कि डिबगर सफलतापूर्वक शुरू हो गया है लॉन्च किया जाएगा।

निर्दिष्ट स्थान पर एक ब्रेकपॉइंट लगाने के लिए, डिबगर को स्रोत कोड में कॉल करें जैसा कि निम्नलिखित कोड में दिखाया गया है।

// myscript.js 
x = 5; 
setTimeout(() => { 
   debugger; 
   console.log('world'); 
}, 1000); 
console.log('hello');

निम्नलिखित चरण कमांड का एक सेट है जो एक नोड के साथ उपयोग कर सकता है।

अनु क्रमांक स्टेपिंग कमांड और विवरण
1

cont,c

जारी रखें

2

next,n

आगे

3

step,s

अंदर आएं

4

out,o

बाहर कदम

5

pause

कोड रोकें। डेवलपर टूल में ठहराव के समान

नोड की डिबगिंग कमांड की पूरी सूची यहां पाई जा सकती है - https://nodejs.org/api/debugger.html।

विजुअल स्टूडियो कोड और डीबगिंग

विज़ुअल स्टूडियो कोड की प्रमुख विशेषताओं में से एक Node.js रनटाइम के लिए इन-बिल्ट डीबगिंग समर्थन है। अन्य भाषाओं में कोड डीबग करने के लिए, यह डीबगर एक्सटेंशन प्रदान करता है।

डीबगर सुविधाओं की एक बहुतायत प्रदान करता है जो हमें कॉन्फ़िगरेशन फ़ाइलों को लॉन्च करने, लागू करने / हटाने / अक्षम करने और ब्रेकप्वाइंट, चर को सक्षम करने, या डेटा निरीक्षण को सक्षम करने आदि की अनुमति देता है।

VS कोड का उपयोग करके डिबगिंग पर एक विस्तृत गाइड यहां पाया जा सकता है - https://code.visualstudio.com/docs/editor/debugging