वार बनाम जावास्क्रिप्ट छोड़ें

| | |

ECMAScript6 (ES6) के रिलीज के साथ जावास्क्रिप्ट भाषा में नई सुविधाएँ जोड़ी गई हैं। इनमें से एक विशेषता हमारे चर घोषित करने के तरीके को प्रभावित करती है। let और const को जोड़ने के साथ, हर प्रकार के प्रश्न थे कि प्रत्येक चर घोषणा का उपयोग कब किया जाए।

इसमें लेख, हम प्रत्येक विकल्प के बारे में बात करते हैं, उनकी परिभाषा और जावास्क्रिप्ट वातावरण में उपयोग के बारे में।

Pre-ES6: Var

ES6 के जारी होने से पहले, कीवर्ड चर var की घोषणा थी।

वेरिएबल को बिना किसी त्रुटि के पुन: घोषित और अद्यतन किया जा सकता है

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

स्कोप

स्कोप हमें बताता है कि क्या चर हमारे उपयोग के लिए उपलब्ध हैं - हमारे पास ऐसे चर हैं जो विश्व स्तर पर या स्थानीय रूप से स्कोप किए जा सकते हैं। क्या होगा यदि हमारे पास एक ही चर घोषणा है, लेकिन वैश्विक है और दूसरा स्थानीय है?

जब हमारे संस्करण को समारोह के बाहर घोषित किया जाता है, तो यह विश्व स्तर पर हमारे लिए विश्व स्तर पर उपलब्ध होता है। जब फ़ंक्शन में "हैलो" घोषित किया जाता है, तो यह केवल फ़ंक्शन के लिए उपलब्ध होता है - कार्यात्मक या स्थानीय दायरे के साथ

जब हमारे पास एक चर घोषणा होती है जो समान होती है, लेकिन दायरा अलग होता है, तो फ़ंक्शन में var वैश्विक var के असाइनमेंट को नहीं बदलता है, यहां तक कि helloWorld () के आह्वान के साथ भी। चूंकि फ़ंक्शन में "हैलो" नाम के साथ var घोषित किया गया है, यह वैकल्पिक परिभाषा की वैश्विक पहुंच के भीतर प्रतीत नहीं होता है।

होइस्ट

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

यहां, "हैलो" फहराया जाता है और आपकी पहुंच के शीर्ष पर घोषित किया जाता है। तो मूल रूप से कंप्यूटर इस तरह से कोड की व्याख्या करता है:

जावास्क्रिप्ट इंजन देखता है कि हैलो मौजूद है लेकिन यह नहीं जानता कि अगले चरण तक हैलो कैसे परिभाषित किया जाता है।

आखिरकार डेवलपर्स जिन्होंने ईसीएमएस्क्रिप्ट मानक बनाने में मदद की महसूस किया कि var के साथ कुछ छोटी-मोटी समस्याएं थीं जिससे उनका समय और पैसा खर्च हो सकता था। इसलिए उन्होंने और कड़े कीवर्ड बनाने का फैसला किया। इससे ES6 में "छुट्टी" और "लागत" का निर्माण हुआ

ES6:. चलो

let कीवर्ड कई मायनों में var कीवर्ड के समान है। मुख्य अंतर हैं जिस तरह से त्रुटियां वापस आती हैं और प्रत्येक कीवर्ड का दायरा परिभाषित किया जाता है। हर कोई"; कंसोल.लॉग (हैलो)।

वेरिएबल घोषित और प्रारंभ किए गए let कीवर्ड के साथ पुन: असाइन किए जा सकते हैं, लेकिन उन्हें पुन: घोषित नहीं किया जा सकता है

जब आप जावास्क्रिप्ट कंसोल में उपरोक्त कोड चलाते हैं, तो अंतिम पंक्ति एक त्रुटि लौटाती है:

सिंटैक्स त्रुटि: पहचानकर्ता ` hello` को पहले ही घोषित किया जा चुका है

var के विपरीत, let का उपयोग करके वेरिएबल घोषित करने से इसकी घोषणा नहीं हो सकेगी। चर का नाम। हालांकि, यदि आप चाहें तो फिर से असाइन कर सकते हैं, जैसा कि ऊपर दिए गए उदाहरण में दिखाया गया है। >वर. नियमों के अतिरिक्त जो वैश्विक या स्थानीय दायरा हमें देता है, let के साथ एक अतिरिक्त बाधा है। कोड ब्लॉक में घोषित चर केवल उस कोड ब्लॉक के लिए उपलब्ध हैं। यह फंक्शनल स्कोप के समान है, क्योंकि फंक्शन्स कोड के ब्लॉक होते हैं जिन्हें उस फंक्शन के भीतर अलग-अलग ब्लॉक्स के द्वारा आगे भी ले जाया जा सकता है।

इस कोड में कोई त्रुटि नहीं है क्योंकि हैलो के दो उदाहरणों को अलग-अलग चर के रूप में माना जाता है क्योंकि उनके अलग-अलग क्षेत्र होते हैं।

होस्टिंग

होस्टिंग एक अन्य क्षेत्र है जहां let और var घोषणाएं समान हैं। "वार", जब उठाया जाता है, तो अपरिभाषित के रूप में प्रारंभ किया जाता है। हालांकि, "छोड़ें" एक संदर्भ त्रुटि उत्पन्न करता है यदि आप इसे प्रारंभ करने से पहले इसका उपयोग करने का प्रयास करते हैं।

ध्यान दें कि वाक्य रचना की दृष्टि से let कीवर्ड सबसे अच्छा विकल्प है। ऐसा इसलिए है क्योंकि त्रुटियां तब उत्पन्न होती हैं जब आप किसी चर को फिर से घोषित करने का प्रयास कर सकते हैं या आरंभीकरण प्रक्रिया से पहले उसका उपयोग कर सकते हैं।

ES6: Const

const कीवर्ड में है let कीवर्ड की तुलना में अधिक कठोर गाइड लाइन। const के साथ, वेरिएबल को घोषित या पुन: असाइन नहीं किया जा सकता है। यदि आप const को पुन: असाइन करने का प्रयास करते हैं तो एक TypeError उत्पन्न होता है।

उस ने कहा, वस्तुओं या सरणियों के साथ काम करते समय, वस्तु या सरणी के गुणों को अद्यतन किया जा सकता है। जब तक ऑब्जेक्ट या टेबल की मूल संरचना नहीं बदलती, आप इसे हमेशा अपडेट कर सकते हैं।

जैसा कि उदाहरण से पता चलता है, गुणों के एक नए सेट के लिए कार्य को पुन: असाइन करने के परिणामस्वरूप TypeError: निरंतर चर के लिए असाइनमेंट। त्रुटि होती है। कॉन्स्ट को फिर से असाइन या फिर से घोषित नहीं किया जा सकता है, सिवाय उन मामलों के जहां आप किसी ऑब्जेक्ट में अद्वितीय प्रॉपर्टी को अपडेट करते हैं

स्कोप और लिफ्ट

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

निष्कर्ष

इस लेख में, हमने let, var और लागत . वर्तमान में हमारे पास जितने भी कीवर्ड हैं, उनमें से जब तक आवश्यक न हो var का उपयोग न करना ही बेहतर है। इसके बजाय, let या const का उपयोग करें।

Shop

Learn programming in R: courses

$

Best Python online courses for 2022

$

Best laptop for Fortnite

$

Best laptop for Excel

$

Best laptop for Solidworks

$

Best laptop for Roblox

$

Best computer for crypto mining

$

Best laptop for Sims 4

$

Latest questions

NUMPYNUMPY

psycopg2: insert multiple rows with one query

12 answers

NUMPYNUMPY

How to convert Nonetype to int or string?

12 answers

NUMPYNUMPY

How to specify multiple return types using type-hints

12 answers

NUMPYNUMPY

Javascript Error: IPython is not defined in JupyterLab

12 answers


Wiki

Python OpenCV | cv2.putText () method

numpy.arctan2 () in Python

Python | os.path.realpath () method

Python OpenCV | cv2.circle () method

Python OpenCV cv2.cvtColor () method

Python - Move item to the end of the list

time.perf_counter () function in Python

Check if one list is a subset of another in Python

Python os.path.join () method