जावास्क्रिप्ट रेफरेंस एरर और उसके समाधान को समझना
जावास्क्रिप्ट में, देख रहे हैं a संदर्भ त्रुटि कष्टप्रद हो सकता है, खासकर जब यह आपके कोड के निष्पादन को रोक देता है। एक प्रचलित परिदृश्य यह है कि उपयोग से पहले चर निर्दिष्ट नहीं किए जाते हैं, जिसके परिणामस्वरूप ऐसी त्रुटियां होती हैं।
समस्या एक फ़ंक्शन को कॉल करने से संबंधित है जो बाहरी एपीआई से डेटा पुनर्प्राप्त करता है। यह विशेष समस्या फ़ंक्शन कॉल में वेरिएबल्स को ठीक से घोषित नहीं किए जाने से उत्पन्न होती है। यदि ठीक से प्रबंधित नहीं किया गया, तो इससे आपका कोड टूट सकता है।
चाहे आप जावास्क्रिप्ट एपीआई के साथ काम कर रहे हों या गतिशील मूल्यों के साथ एक स्क्रिप्ट का निर्माण कर रहे हों, उन्हें पास करने से पहले चर निर्दिष्ट करना आवश्यक है। यदि नहीं, तो आपको "ReferenceError: वेरिएबल परिभाषित नहीं है" संदेश प्राप्त हो सकता है।
यह पोस्ट बताएगी कि इसे ठीक करने के लिए अपने जावास्क्रिप्ट फ़ंक्शन को कैसे बदलें संदर्भ त्रुटि. हम भविष्य के कार्यान्वयन में इस समस्या से बचने के लिए मापदंडों को सही ढंग से परिभाषित और पारित करने के तरीके पर भी चर्चा करेंगे।
आज्ञा | उपयोग का उदाहरण |
---|---|
fetch() | लाना() कमांड किसी दिए गए यूआरएल के लिए नेटवर्क अनुरोध शुरू करता है। इस मामले में, यह एपीआई से विनिमय दरें प्राप्त करता है और एक वादा प्रदान करता है, जिससे हमें बाहरी सेवाओं से डेटा पुनर्प्राप्त करने जैसे अतुल्यकालिक कार्य करने की अनुमति मिलती है। |
then() | तब() विधि पूर्ण किए गए वादे की प्रतिक्रिया को संभालती है। बाद लाना() एपीआई डेटा प्राप्त करता है, तब() एपीआई द्वारा आपूर्ति किए गए JSON डेटा को संसाधित करता है। |
catch() | पकड़ना() त्रुटियों को प्रबंधित करने के लिए वादा श्रृंखला में विधि जोड़ी गई है। इस उदाहरण में, यह फ़ेच ऑपरेशन के दौरान होने वाली समस्याओं का पता लगाता है और लॉग करता है, जैसे नेटवर्क आउटेज या गलत उत्तर। |
axios.get() | Node.js उदाहरण का उपयोग करता है axios.get() एपीआई एंडपॉइंट पर HTTP GET अनुरोध भेजने के लिए। यह फ़ंक्शन HTTP क्वेरीज़ को सुव्यवस्थित करता है और एक वादा लौटाता है जो सर्वर के डेटा के साथ हल होता है। |
mockResolvedValue() | जेस्ट परीक्षण में, मॉकरिजॉल्डवैल्यू() के व्यवहार का उपहास उड़ाने के लिए प्रयोग किया जाता है axios`। परीक्षण कारणों से, get() का उपयोग करें नियंत्रित उत्तर लौटाने के लिए। यह सुनिश्चित करता है कि इकाई परीक्षण एपीआई सफलता परिस्थितियों का अनुकरण करता है। |
mockRejectedValue() | के समान मॉकरिजॉल्डवैल्यू(), द मॉकरिजेक्टेडवैल्यू() जेस्ट में विधि एक त्रुटि प्रतिक्रिया को दोहराती है, जैसे कि नेटवर्क समस्या, हमें यह परीक्षण करने की अनुमति देती है कि हमारा फ़ंक्शन विफलताओं को कैसे संभालता है। |
expect() | अपेक्षा करना() एक जेस्ट फ़ंक्शन है जो परीक्षणों में अपेक्षित परिणामों का दावा करता है। उदाहरणों में, यह सुनिश्चित करता है कि सही दर लौटाई गई है या एपीआई अनुरोध विफल होने पर एक अपवाद फेंक दिया गया है। |
rejects.toThrow() | जेस्ट का उपयोग करता है अस्वीकार.toThrow() यह सुनिश्चित करने की विधि कि कोई वादा त्रुटि लौटाता है। यह विशेष रूप से तब उपयोगी होता है जब यह मूल्यांकन किया जाता है कि फ़ंक्शन अस्वीकृत एपीआई कॉल को कैसे संभालता है, जैसे कि नकली नेटवर्क समस्याएं। |
document.body.innerHTML | DOM मैनिपुलेशन कमांड document.body.innerHTML पृष्ठ पर मुख्य तत्व की सामग्री को संशोधित करता है। उदाहरण में, प्राप्त मुद्रा दर वेबपेज पर गतिशील रूप से प्रदर्शित होती है। |
जावास्क्रिप्ट एपीआई कॉल में ReferenceError का समाधान
प्रस्तावित उदाहरणों में, जावास्क्रिप्ट स्क्रिप्ट का उद्देश्य एपीआई, विशेष रूप से बिटपे सेवा से विनिमय दरों को पुनः प्राप्त करना है। मुख्य मुद्दा एक है संदर्भ त्रुटि का उपयोग करते समय अपरिभाषित चर द्वारा उत्पन्न जीसी() समारोह। इसे संबोधित करने के लिए, पहला कदम यह सुनिश्चित करना है कि फ़ंक्शन को दिए गए पैरामीटर, जैसे 'एथ' और 'यूएसडी', स्ट्रिंग के रूप में सही ढंग से घोषित किए गए हैं। अपरिभाषित चर को जावास्क्रिप्ट द्वारा संसाधित नहीं किया जा सकता है, इसलिए उन्हें उद्धरण चिह्नों में समाहित करने से समस्या हल हो जाती है और फ़ेच अनुरोध को उचित URL निर्माण के साथ आगे बढ़ने की अनुमति मिलती है।
फ़ेच एपीआई इस दृष्टिकोण का एक महत्वपूर्ण घटक है, जो स्क्रिप्ट को बाहरी सर्वर से अतुल्यकालिक रूप से डेटा प्राप्त करने की अनुमति देता है। इस उदाहरण में, get() दो पैरामीटर (var1 और var2) द्वारा निर्दिष्ट URL पर एक HTTP अनुरोध भेजता है। यूआरएल संरचना महत्वपूर्ण है, और इसकी गतिशील पीढ़ी यह गारंटी देती है कि उपयोगकर्ता इनपुट के आधार पर उपयुक्त समापन बिंदु को कॉल किया जाता है। डेटा को पुनः प्राप्त करने के बाद, इसका उपयोग करके पार्स किया जाता है res.json() प्रतिक्रिया को JSON प्रारूप में परिवर्तित करने के लिए। परिणामी विनिमय दर को DOM संशोधन के माध्यम से HTML बॉडी में दिखाया जाता है, जो वास्तविक समय में उपयोगकर्ता इंटरफ़ेस को अपडेट करता है।
Node.js संस्करण में, हम उपयोग करते हैं अक्ष फ़ेच के बजाय, बैकएंड संदर्भों में HTTP अनुरोधों को संभालने के लिए एक अधिक मजबूत पैकेज। Axios त्रुटि प्रबंधन में सुधार करता है और प्रतिक्रिया पार्सिंग प्रक्रिया को सुव्यवस्थित करता है। स्क्रिप्ट में, एक्सियोस एपीआई एंडपॉइंट के लिए एक GET अनुरोध करता है, डेटा एकत्र करता है, और कंसोल में विनिमय दर प्रदर्शित करता है। इसके अलावा, स्क्रिप्ट यह सुनिश्चित करती है कि त्रुटि के अन्य संभावित स्रोत को हटाते हुए, एपीआई कॉल करने से पहले दोनों पैरामीटर फ़ंक्शन में प्रदान किए जाते हैं।
इन कार्यात्मकताओं की स्थिरता को मान्य करने के लिए, इकाई परीक्षण का उपयोग करके लिखा गया था जेस्ट रूपरेखा। ये परीक्षण सफल और असफल एपीआई कॉल दोनों को दोहराने के लिए एक्सियोस लाइब्रेरी को खराब कर देते हैं। इससे हमें यह सुनिश्चित करने में मदद मिलती है कि फ़ंक्शन सभी संभावित परिदृश्यों को कवर करता है, जैसे कि जब एपीआई एक वैध दर प्रदान करता है या जब कोई त्रुटि होती है, जैसे नेटवर्क आउटेज। इन परीक्षणों को शामिल करके, हम आत्मविश्वास से उत्पादन परिवेश में कोड जारी कर सकते हैं, यह जानते हुए कि यह अपेक्षा के अनुरूप प्रदर्शन करेगा। फ्रंट-एंड और बैक-एंड दोनों समाधानों का उपयोग यह सुनिश्चित करता है कि समस्या का पूरी तरह से समाधान हो गया है, जिसमें प्रदर्शन और त्रुटि लचीलापन दोनों को बढ़ाने पर जोर दिया गया है।
ReferenceError का समाधान: जावास्क्रिप्ट एपीआई फ़ेच में वेरिएबल परिभाषित नहीं हैं
यह दृष्टिकोण एक बुनियादी फ्रंटएंड जावास्क्रिप्ट पद्धति पर केंद्रित है जो बाहरी सेवा से दरें प्राप्त करने के लिए फ़ेच एपीआई का लाभ उठाता है। हम यह सुनिश्चित करेंगे कि वेरिएबल सही ढंग से परिभाषित किए गए हैं और त्रुटियों को उचित रूप से संभालेंगे।
// Define the function with two parameters
function getRates(var1, var2) {
// Define the URL with the parameters
let url = 'https://bitpay.com/rates/' + var1 + '/' + var2;
// Fetch data from the URL
fetch(url)
.then(res => {
if (!res.ok) throw new Error('Network response was not ok');
return res.json();
})
.then(out => {
// Update the body with the rate
document.body.innerHTML = 'Rate: ' + out.data.rate;
})
.catch(error => console.error('There was an error:', error));
}
// Correctly call the function with string parameters
getRates('eth', 'usd');
Node.js में अपरिभाषित वेरिएबल्स और त्रुटि प्रबंधन को संभालना
यह बैकएंड तकनीक इनपुट सत्यापन और त्रुटि प्रबंधन के साथ-साथ एपीआई अनुरोध के लिए Node.js और axios का उपयोग करती है।
const axios = require('axios');
// Function to get exchange rates
function getRates(var1, var2) {
// Validate input parameters
if (!var1 || !var2) {
throw new Error('Both currency parameters must be defined');
}
// Define the URL
const url = 'https://bitpay.com/rates/' + var1 + '/' + var2;
// Make the request using axios
axios.get(url)
.then(response => {
console.log('Rate:', response.data.data.rate);
})
.catch(error => {
console.error('Error fetching rate:', error.message);
});
}
// Correctly call the function
getRates('eth', 'usd');
जेस्ट का उपयोग करके जावास्क्रिप्ट में गेटरेट्स फ़ंक्शन का परीक्षण इकाई
यह परीक्षण स्क्रिप्ट यह सुनिश्चित करने के लिए जेस्ट का उपयोग करती है कि फ़ंक्शन सफल एपीआई अनुरोधों और त्रुटि स्थितियों सहित विभिन्न परिदृश्यों को संभाल सकता है।
const axios = require('axios');
const { getRates } = require('./getRates');
jest.mock('axios');
// Test successful API call
test('should return correct rate', async () => {
axios.get.mockResolvedValue({ data: { data: { rate: 2500 } } });
const rate = await getRates('eth', 'usd');
expect(rate).toBe(2500);
});
// Test API call failure
test('should handle error', async () => {
axios.get.mockRejectedValue(new Error('Network Error'));
await expect(getRates('eth', 'usd')).rejects.toThrow('Network Error');
});
जावास्क्रिप्ट एपीआई कॉल में परिवर्तनीय परिभाषाओं को संभालना
इससे निपटने के लिए उचित परिवर्तनीय दायरा और आरंभीकरण महत्वपूर्ण हैं संदर्भ त्रुटि जावास्क्रिप्ट में, विशेष रूप से एपीआई कॉल से निपटते समय। जावास्क्रिप्ट में वेरिएबल्स को ठीक से परिभाषित और घोषित करने के लिए, उपयोग करें होने देना या कॉन्स्ट. उपयोग से पहले वेरिएबल घोषित करने में विफलता, या उन्हें उनके दायरे से बाहर बुलाने के परिणामस्वरूप अक्सर "ReferenceError: वेरिएबल परिभाषित नहीं है" जैसी त्रुटियां होती हैं। एपीआई क्वेरी बनाते समय, यह सुनिश्चित करना महत्वपूर्ण है कि तर्क ठीक से भरे गए हैं।
बाहरी एपीआई के साथ इंटरफ़ेस करने वाले एप्लिकेशन विकसित करते समय, आपको अतिरिक्त रूप से क्रियाओं की अतुल्यकालिक प्रकृति पर विचार करना चाहिए। जबकि फ़ेच एपीआई वादों का उपयोग करके अतुल्यकालिक गतिविधियों को संभालता है, इसके साथ त्रुटि प्रबंधन जोड़ना महत्वपूर्ण है कोशिश करो...पकड़ो ब्लॉक करें या उपयोग करें ।पकड़ना() संभावित विफलताओं को पकड़ने के वादे के बाद कार्य करें। यह अप्रत्याशित समस्याओं को संपूर्ण एप्लिकेशन को बाधित करने से रोकता है। अच्छा त्रुटि प्रबंधन शानदार विफलता और प्रासंगिक त्रुटि संदेश प्रदान करके उपयोगकर्ता अनुभव को बेहतर बनाता है।
इसके अलावा, बाहरी एपीआई प्रश्नों से निपटने के दौरान सुरक्षा पर ध्यान दिया जाना चाहिए। आपको आने वाले सभी डेटा को सत्यापित करना होगा, खासकर जब हमारी स्थिति में मुद्राओं जैसे परिवर्तनीय मापदंडों से निपटना हो। एपीआई अनुरोध करने से पहले इनपुट को साफ करने से एपीआई के दुरुपयोग या इंजेक्शन हमलों जैसी संभावित सुरक्षा कमजोरियों को रोकने में मदद मिल सकती है। इनपुट सत्यापन के लिए सर्वोत्तम प्रथाओं का पालन करना और यूआरएल में उपयोगकर्ता-जनित डेटा के सीधे उपयोग से बचना आधुनिक वेब विकास में एक महत्वपूर्ण रणनीति है।
जावास्क्रिप्ट एपीआई कॉल त्रुटियों पर अक्सर पूछे जाने वाले प्रश्न
- जावास्क्रिप्ट में ReferenceError का क्या कारण है?
- एक संदर्भ त्रुटि तब होती है जब किसी चर को परिभाषित करने से पहले उसका उपयोग किया जाता है। इसे रोकने के लिए, हमेशा वेरिएबल्स को इस रूप में घोषित करें let या const उनका आह्वान करने से पहले.
- मैं "एथ परिभाषित नहीं है" त्रुटि को कैसे ठीक कर सकता हूं?
- सुनिश्चित करें कि 'एथ' एक स्ट्रिंग के रूप में प्रदान किया गया है, अपरिभाषित चर के रूप में नहीं। फ़ंक्शन को कॉल करें gc('eth', 'usd').
- स्क्रिप्ट में फ़ेच() की क्या भूमिका है?
- fetch() फ़ंक्शन एपीआई एंडपॉइंट पर एक HTTP अनुरोध भेजता है। यह एक वादा लौटाता है जो बाहरी सेवा से डेटा का समाधान करता है।
- मैं एपीआई कॉल के दौरान त्रुटियों को कैसे संभाल सकता हूं?
- त्रुटियों को संभालने के लिए, उपयोग करें .catch() वादे के बाद या कोड को a में लपेटें try...catch अपवादों को पकड़ने के लिए ब्लॉक करें।
- जावास्क्रिप्ट में लेट और वेर के बीच क्या अंतर है?
- let ब्लॉक-स्कोप्ड है, जिसका अर्थ है कि यह केवल घुंघराले ब्रैकेट के निकटतम सेट के भीतर रहता है, लेकिन var कार्य-क्षेत्र है और यदि सही ढंग से उपयोग न किया जाए तो यह अप्रत्याशित व्यवहार का कारण बन सकता है।
जावास्क्रिप्ट एपीआई कॉल समस्याओं को ठीक करने के मुख्य उपाय
जावास्क्रिप्ट में "रेफरेंस एरर" को ठीक करने में ज्यादातर यह सुनिश्चित करना शामिल है कि उपयोग से पहले वेरिएबल्स को ठीक से परिभाषित किया गया है। 'एथ' जैसे मापदंडों को स्ट्रिंग के रूप में परिभाषित करें और तत्काल समस्या को ठीक करने के लिए इनपुट को मान्य करें।
यह रणनीति, पर्याप्त त्रुटि प्रबंधन के उपयोग के साथ संयुक्त है पकड़ना() और इनपुट सत्यापन के परिणामस्वरूप बाहरी एपीआई से निपटने के लिए लचीला कोड प्राप्त हो सकता है। यह रनटाइम गलतियों को कम करते हुए अधिक कुशल प्रक्रियाओं और बेहतर उपयोगकर्ता अनुभव को सुनिश्चित करता है।
जावास्क्रिप्ट फ़ंक्शन त्रुटियों और एपीआई हैंडलिंग के लिए संदर्भ
- जावास्क्रिप्ट पर अधिक जानकारी के लिए संदर्भ त्रुटि और परिवर्तनीय घोषणाएँ, मोज़िला डेवलपर नेटवर्क (एमडीएन) पर जाएँ: एमडीएन - संदर्भ त्रुटि: परिभाषित नहीं .
- के उचित उपयोग के बारे में जानने के लिए लाना() जावास्क्रिप्ट में एपीआई कॉल के लिए फ़ंक्शन, एमडीएन पर आधिकारिक फ़ेच एपीआई दस्तावेज़ देखें: एमडीएन - फ़ेच एपीआई .
- के उपयोग पर मार्गदर्शन के लिए axios HTTP अनुरोधों को संभालने के लिए Node.js में लाइब्रेरी, Axios GitHub रिपॉजिटरी से परामर्श लें: एक्सियोस - गिटहब .
- यह पता लगाने के लिए कि कैसे कार्यान्वित किया जाए इकाई परीक्षण जेस्ट का उपयोग करने वाले जावास्क्रिप्ट फ़ंक्शंस के लिए, आधिकारिक जेस्ट दस्तावेज़ देखें: मज़ाक - आधिकारिक दस्तावेज़ीकरण .