वैरिएबल डेटा का ऐसा स्ट्रक्चर है जिसकी मदद से वैल्यू को एक प्रतिनिधि नाम असाइन किया जाता है. इनमें किसी भी तरह का डेटा हो सकता है.
वैरिएबल के नाम को आइडेंटिफ़ायर कहा जाता है. एक मान्य आइडेंटिफ़ायर को उसका पालन करना होगा ये नियम:
- आइडेंटिफ़ायर में यूनिकोड अक्षर, डॉलर साइन ($), अंडरस्कोर हो सकते हैं वर्ण (_), अंक (0-9) के तौर पर इस्तेमाल किए जा सकते हैं. साथ ही, कुछ यूनिकोड वर्ण भी इस्तेमाल किए जा सकते हैं.
- आइडेंटिफ़ायर में खाली सफ़ेद जगह नहीं हो सकती, क्योंकि पार्सर खाली सफ़ेद जगह का इस्तेमाल करके
इनपुट एलिमेंट को अलग-अलग कर सकते हैं. उदाहरण के लिए, अगर आपने किसी वैरिएबल को
myVariable
के बजायmy Variable
, पार्सर को दो आइडेंटिफ़ायर दिखते हैं,my
औरVariable
दिखाता है और सिंटैक्स की गड़बड़ी दिखाता है ("अनचाहा टोकन: आइडेंटिफ़ायर"). आइडेंटिफ़ायर, किसी अक्षर, अंडरस्कोर (
_
) या डॉलर के निशान ($
) से शुरू होने चाहिए. वे अंकों से शुरू नहीं हो सकते, ताकि संख्याओं और आइडेंटिफ़ायर:let 1a = true; > Uncaught SyntaxError: Invalid or unexpected token
अगर JavaScript किसी आइडेंटिफ़ायर की शुरुआत में नंबर की अनुमति देता है, तो सिर्फ़ संख्याओं से बने आइडेंटिफ़ायर होने की वजह से, इस तरह इस्तेमाल की जाने वाली संख्याओं के बीच टकराव होता है आइडेंटिफ़ायर के तौर पर इस्तेमाल की जाने वाली संख्याएं और संख्याएं:
let 10 = 20 10 + 5 > ?
"बुक किए गए शब्द" जो पहले से ही वाक्यात्मक रूप से अर्थपूर्ण हैं, उनका आइडेंटिफ़ायर के रूप में उपयोग नहीं किया जा सकता.
आइडेंटिफ़ायर में खास वर्ण (
! . , / \ + - * =
) नहीं हो सकते.
आइडेंटिफ़ायर बनाने के लिए यहां दिए गए नियम सख्त नहीं हैं, लेकिन वे आपके कोड का रखरखाव आसान बनाने के लिए, इंडस्ट्री के सबसे सही तरीकों का इस्तेमाल करें. अगर आपके खास प्रोजेक्ट के अलग-अलग स्टैंडर्ड हैं. इसलिए, एक जैसा रहने के लिए उन स्टैंडर्ड का पालन करें.
JavaScript में पहले से मौजूद तरीकों और प्रॉपर्टी के ज़रिए सेट किए गए उदाहरण का पालन करते हुए, कैमल केस (इसे "camelCase) के तौर पर भी स्टाइल किया जाता है, यह आम बात है जो कई शब्दों से मिलकर बने हों. ऊंटों का केस बेहतर बनाने के लिए हर शब्द के पहले अक्षर को छोड़कर, पहले अक्षर को बड़ा करना बिना खाली जगह के पढ़ने में मदद करता है.
let camelCasedIdentifier = true;
कुछ प्रोजेक्ट में कॉन्टेक्स्ट और प्रकृति के आधार पर, नाम रखने के अन्य तरीके इस्तेमाल किए जाते हैं डेटा का एक उदाहरण है. उदाहरण के लिए, क्लास का पहला अक्षर आम तौर पर, नाम कैपिटल लेटर में होता है. इसलिए, कई शब्दों वाले वर्ग के नामों में अक्सर ऊंट के अलग-अलग तरह के नामों का इस्तेमाल होता है इसे आम तौर पर "ऊपरी ऊंट का केस" कहा जाता है या Pascal केस.
class MyClass {
}
आइडेंटिफ़ायर को कम शब्दों में यह बताना चाहिए कि उनमें मौजूद डेटा किस तरह का है (इसके लिए
उदाहरण, theNumberOfDaysInTheCurrentMonth
से currentMonthDays
बेहतर नाम है)
और एक ही नज़र में आसानी से पढ़ें (originalValue
, val
से बेहतर है). कॉन्टेंट बनाने
इस मॉड्यूल में इस्तेमाल किए गए myVariable
आइडेंटिफ़ायर, इसके संदर्भ में काम करते हैं
कुछ उदाहरण हो सकते हैं, लेकिन वे प्रोडक्शन कोड के मामले में बहुत उपयोगी नहीं होंगे, क्योंकि
उन्हें इस बात की कोई जानकारी नहीं देनी चाहिए कि उनमें कौनसा डेटा है.
आइडेंटिफ़ायर में मौजूद डेटा के बारे में सटीक जानकारी नहीं देनी चाहिए, क्योंकि
स्क्रिप्ट उस डेटा पर कैसे काम करती हैं या इस आधार पर बदल सकती हैं कि
वे फ़ैसले जो भविष्य में रखरखाव करने वाले लोग लेते हैं. उदाहरण के लिए, मूल रूप से
miles
आइडेंटिफ़ायर को बाद में, किलोमीटर में वैल्यू में बदलना पड़ सकता है
की ज़रूरत होती है, जिसके लिए मेंटेनर को उस वैरिएबल के किसी भी रेफ़रंस को बदलकर यह
आने वाले समय में भ्रम की स्थिति से बचें. इसे रोकने के लिए, distance
को अपने आइडेंटिफ़ायर के तौर पर इस्तेमाल करें
आज़माएं.
JavaScript उन आइडेंटिफ़ायर को खास अधिकार या मतलब नहीं देता है जो
अंडरस्कोर वर्णों (_
) से शुरू होते हैं, लेकिन आम तौर पर उनका इस्तेमाल यह दिखाने के लिए किया जाता है
वैरिएबल, तरीका या प्रॉपर्टी "निजी" होती है. इसका मतलब है कि यह सिर्फ़
उस ऑब्जेक्ट के संदर्भ में इस्तेमाल करने के लिए जिसमें वह मौजूद है. इसे नहीं
उस संदर्भ से बाहर ऐक्सेस या संशोधित किया जा सकता है. यह एक कन्वेंशन को आगे ले जाया गया है
अन्य प्रोग्रामिंग भाषाओं से लिया हुआ है और JavaScript के
निजी प्रॉपर्टी.
वैरिएबल की जानकारी
JavaScript को किसी आइडेंटिफ़ायर के बारे में जानकारी देने के कई तरीके हैं.
जिसका नाम "एलान करना" है एक वैरिएबल. let
, const
, का इस्तेमाल करके वैरिएबल तय किया जाता है
या var
कीवर्ड.
let myVariable;
let
या var
का इस्तेमाल करके, उस वैरिएबल का एलान करें जिसे किसी भी समय बदला जा सकता है. ये
कीवर्ड, JavaScript इंटरप्रेटर को बताते हैं कि वर्णों की स्ट्रिंग
ऐसा आइडेंटिफ़ायर जिसमें वैल्यू मौजूद हो सकती है.
मॉडर्न कोड बेस में काम करते समय, var
के बजाय let
का इस्तेमाल करें. var
अब भी काम करेगा
आधुनिक ब्राउज़र में देखा है, लेकिन इसमें कुछ ऐसे अनजाने व्यवहार हैं जिनके बारे में
का सबसे पुराना वर्शन है, और उसे बाद में
पुराने सिस्टम के साथ काम करने की सुविधा को बनाए रखें. कुछ समस्याओं को हल करने के लिए, let
को ES6 में जोड़ा गया था
var
को डिज़ाइन किया गया है.
वैरिएबल को वैल्यू असाइन करके, घोषित वैरिएबल को शुरू किया जाता है. किसी
सिंगल बराबर के चिह्न (=
) का इस्तेमाल करके, किसी वैरिएबल के लिए वैल्यू असाइन या फिर से असाइन करें. आप यह कर सकते हैं:
इसे उसी स्टेटमेंट के हिस्से के तौर पर शामिल करें जिसमें इसका एलान किया गया है:
let myVariable = 5;
myVariable + myVariable
> 10
किसी वैरिएबल को शुरू किए बिना भी, let
(या var
) का एलान किया जा सकता है
है या नहीं. अगर ऐसा किया जाता है, तो वैरिएबल की शुरुआती वैल्यू undefined
होगी. ऐसा तब तक होगा, जब तक आपकी
कोड इसे एक मान असाइन करता है.
let myVariable;
myVariable;
> undefined
myVariable = 5;
myVariable + myVariable
> 10
undefined
वैल्यू वाला वैरिएबल, तय नहीं किए गए वैरिएबल से अलग होता है
जिसके आइडेंटिफ़ायर का एलान अब तक नहीं किया गया है. किसी ऐसे वैरिएबल का रेफ़रंस देना जो आपने नहीं किया है
एलान की वजह से गड़बड़ी हुई है.
myVariable
> Uncaught ReferenceError: myVariable is not defined
let myVariable;
myVariable
> undefined
किसी आइडेंटिफ़ायर के साथ वैल्यू के संबंध को जोड़ने को आम तौर पर "बाइंडिंग" कहा जाता है.
जो सिंटैक्स let
, var
या const
कीवर्ड के मुताबिक होता है उसे
"ज़रूरी शर्तों की सूची" और कॉमा लगाकर अलग किए गए कई वैरिएबल की जानकारी देने की अनुमति देता है
(उम्मीद के मुताबिक सेमीकोलन के साथ खत्म हो रहा है). इससे ये कोड स्निपेट बन जाते हैं
एक जैसे फ़ंक्शन:
let firstVariable,
secondVariable,
thirdVariable;
let firstVariable;
let secondVariable;
let thirdVariable;
वैरिएबल की वैल्यू फिर से असाइन करने पर let
(या var
) का इस्तेमाल नहीं होता, क्योंकि JavaScript
वैरिएबल के मौजूद होने की जानकारी पहले से है:
let myVariable = true;
myVariable
> true
myVariable = false;
myVariable
> false
वैरिएबल की मौजूदा वैल्यू के आधार पर, उन्हें फिर से नई वैल्यू असाइन की जा सकती हैं:
let myVariable = 10;
myVariable
> 10
myVariable = myVariable * myVariable;
myVariable
> 100
अगर प्रोडक्शन एनवायरमेंट में let
का इस्तेमाल करके, वैरिएबल का एलान करने की कोशिश की जाती है, तो
तो आपको एक सिंटैक्स गड़बड़ी दिखेगी:
let myVariable = true;
let myVariable = false;
> Uncaught SyntaxError: redeclaration of let myVariable
ब्राउज़र डेवलपर टूल
let
(और class
) के लिए फिर से एलान करने की अनुमति है, इसलिए
अपने डेवलपर कंसोल में भी वही गड़बड़ी देखें.
लेगसी ब्राउज़र के साथ काम करने की सुविधा को बनाए रखने के लिए, var
बेवजह फिर से एलान करने की अनुमति देता है
में गड़बड़ी नहीं होगी:
var myVariable = true;
var myVariable = false;
myVariable\
> false
const
const
कीवर्ड का इस्तेमाल करके कॉन्सटेंट बताएं. यह एक ऐसा वैरिएबल होना चाहिए जिसे
तुरंत शुरू हो जाता है और फिर इसे बदला नहीं जा सकता. कॉन्सटेंट के आइडेंटिफ़ायर
उन सभी नियमों का पालन करें जिनका एलान let
(और var
) का इस्तेमाल करके किया गया है:
const myConstant = true;
myConstant
> true
तुरंत वैल्यू असाइन किए बिना, किसी कॉन्स्टेंट को नहीं बताया जा सकता, क्योंकि
कॉन्सटेंट को बनाने के बाद, उन्हें फिर से असाइन नहीं किया जा सकता. इसलिए, शुरू न होने पर
स्थिरांक हमेशा undefined
रहेगा. अगर आपको किसी कॉन्स्टेंट (कॉन्सटेंट) का एलान करना है, तो
इसे शुरू किए बिना, आपको एक सिंटैक्स गड़बड़ी मिलती है:
const myConstant;
Uncaught SyntaxError: missing = in const declaration
const
के साथ तय किए गए वैरिएबल की वैल्यू को उस तरह से बदलना
let
(या var
) की मदद से, तय किए गए वैरिएबल की वैल्यू में बदलाव होने पर एक टाइप
गड़बड़ी:
const myConstant = true;
myConstant = false;
> Uncaught TypeError: invalid assignment to const 'myConstant'
हालांकि, जब किसी ऑब्जेक्ट के साथ कोई कॉन्स्टेंट जुड़ा होता है, तो उसके गुण ऑब्जेक्ट में बदलाव किया जा सकता है.
const constantObject = { "firstvalue" : true };
constantObject
> Object { firstvalue: true }
constantObject.secondvalue = false;
constantObject
> Object { firstvalue: true, secondvalue: false }
वह कॉन्स्टेंट जिसमें कोई ऑब्जेक्ट होता है, उसे नहीं बदला जा सकता बदले जा सकने वाले डेटा की वैल्यू का रेफ़रंस. कॉन्सटेंट को नहीं बदला जा सकता. हालांकि, रेफ़रंस के तौर पर दी गई प्रॉपर्टी की प्रॉपर्टी ऑब्जेक्ट में बदलाव किया जा सकता है, उसे जोड़ा या हटाया जा सकता है:
const constantObject = { "firstvalue" : true };
constantObject = false
> Uncaught TypeError: invalid assignment to const 'constantObject'
जब आपको यह उम्मीद नहीं हो कि कोई वैरिएबल फिर से असाइन किया जाएगा, तो इसे बनाना सबसे सही तरीका है
एक कॉन्स्टेंट. const
का इस्तेमाल करने से, आपकी डेवलपमेंट टीम या आने वाले समय में मैनेज करने वाले लोगों को
प्रोजेक्ट में उस वैल्यू को नहीं बदला जाएगा, ताकि आपके कोड के अनुमान को तोड़ने से बचा जा सके
इसके इस्तेमाल के बारे में बनाया गया है—उदाहरण के लिए, कि एक वैरिएबल आखिरकार
अनुमानित डेटा टाइप के आधार पर आकलन किया गया है.
वैरिएबल का स्कोप
वैरिएबल का स्कोप, स्क्रिप्ट का वह हिस्सा होता है जहां वैरिएबल उपलब्ध होता है.
वैरिएबल के स्कोप के बाहर इसे तय नहीं किया जाएगा—आइडेंटिफ़ायर के तौर पर नहीं
में undefined
वैल्यू हो, लेकिन मानो उसका एलान ही न किया गया हो.
यह इस बात पर निर्भर करता है कि वैरिएबल का एलान करने के लिए, आपने किस कीवर्ड का इस्तेमाल किया है. साथ ही, उस कॉन्टेक्स्ट के आधार पर जिसमें तो स्टेटमेंट ब्लॉक करने के लिए, वैरिएबल का स्कोप किया जा सकता है (ब्लॉक स्कोप), अलग-अलग फ़ंक्शन (फ़ंक्शन का स्कोप) या पूरा JavaScript ऐप्लिकेशन (ग्लोबल स्कोप).
दायरा ब्लॉक करें
आपने let
या const
का इस्तेमाल करके, जिस वैरिएबल का एलान किया है उसे उसके सबसे नज़दीक के दायरे में रखा जाता है
इसमें ब्लॉक करने वाला स्टेटमेंट शामिल है,
इसका मतलब है कि वैरिएबल को सिर्फ़ उसी ब्लॉक में ऐक्सेस किया जा सकता है. कोई
किसी ब्लॉक के स्कोप वाले वैरिएबल को, इसके शामिल ब्लॉक के बाहर ऐक्सेस करने से एक जैसी वजह होती है
गड़बड़ी, किसी ऐसे वैरिएबल को ऐक्सेस करने की कोशिश करने पर हुई है जो मौजूद नहीं है:
{
let scopedVariable = true;
console.log( scopedVariable );
}
> true
scopedVariable
> ReferenceError: scopedVariable is not defined
जहां तक JavaScript का सवाल है, ब्लॉक स्कोप वाला वैरिएबल मौजूद नहीं है उस ब्लॉक के बाहर होगा जिसमें वह मौजूद है. उदाहरण के लिए, किसी कॉन्स्टेंट (कॉन्सटेंट) का एलान किया जा सकता है और फिर उस ब्लॉक के बाहर एक और स्थिरांक को घोषित कर दें, जो एक ही आइडेंटिफ़ायर:
{
const myConstant = false;
}
const myConstant = true;
scopedConstant;
> true
हालांकि, घोषित वैरिएबल अपने पैरंट ब्लॉक में नहीं बढ़ाया जा सकता, लेकिन यह है सभी डिसेंडेंट ब्लॉक में उपलब्ध:
{
let scopedVariable = true;
{
console.log( scopedVariable );
}
}
> true
किसी डिसेंडेंट ब्लॉक में, एलान किए गए वैरिएबल की वैल्यू बदली जा सकती है:
{
let scopedVariable = false;
{
scopedVariable = true;
}
console.log( scopedVariable );
}
> true
डिसेंडेंट में, let
या const
का इस्तेमाल करके नया वैरिएबल शुरू किया जा सकता है
बिना किसी गड़बड़ी के ब्लॉक भी कर दिया जाता है, भले ही वह किसी वैरिएबल के
पैरंट ब्लॉक:
{
let scopedVariable = false;
{
let scopedVariable = true;
}
console.log( scopedVariable );
}
> false
फ़ंक्शन का स्कोप
var
का इस्तेमाल करके घोषित किए गए वैरिएबल, उनके सबसे नज़दीक वाले फ़ंक्शन के दायरे में आते हैं
(या क्लास में स्टैटिक इनिशलाइज़ेशन ब्लॉक).
function myFunction() {
var scopedVariable = true;
return scopedVariable;
}
scopedVariable;
> ReferenceError: scopedVariable is not defined
किसी फ़ंक्शन को कॉल किए जाने के बाद भी ऐसा होता है. भले ही वैरिएबल के चलने के दौरान, वैरिएबल को शुरू किया जा सकता है. फ़ंक्शन के स्कोप के बाहर उपलब्ध नहीं है:
function myFunction() {
var scopedVariable = true;
return scopedVariable;
}
scopedVariable;
> ReferenceError: scopedVariable is not defined
myFunction();
> true
scopedVariable;
> ReferenceError: scopedVariable is not defined
ग्लोबल स्कोप
ग्लोबल वैरिएबल, पूरे JavaScript ऐप्लिकेशन में उपलब्ध रहता है. किसी भी और सभी ब्लॉक और फ़ंक्शन के अंदर, पेज पर मौजूद किसी भी स्क्रिप्ट में.
वैसे यह एक ज़रूरी डिफ़ॉल्ट लग सकता है, लेकिन वैरिएबल की अनुप्रयोग को ऐक्सेस और संशोधित करने से गैरज़रूरी ओवरहेड, या समान आइडेंटिफ़ायर वाले ऐप्लिकेशन में कहीं और वैरिएबल के साथ टकराव. यह किसी पेज को रेंडर करने में शामिल किसी भी या सभी JavaScript पर लागू होता है, जैसे, तीसरे पक्ष की लाइब्रेरी और उपयोगकर्ताओं के आंकड़े. इसलिए, यह सबसे सही तरीका यह है कि जब भी मुमकिन हो, ग्लोबल स्कोप को प्रदूषित न करें.
पैरंट फ़ंक्शन के बाहर, var
का इस्तेमाल करके या let
या
पैरंट ब्लॉक के बाहर का const
, ग्लोबल है:
var functionGlobal = true; // Global
let blockGlobal = true; // Global
{
console.log( blockGlobal );
console.log( functionGlobal );
}
> true
> true
(function() {
console.log( blockGlobal );
console.log( functionGlobal );
}());
> true
> true
साफ़ तौर पर इसकी जानकारी दिए बिना, वैरिएबल के लिए कोई वैल्यू असाइन करना
कभी भी var
, let
या const
का इस्तेमाल नहीं करना) की वजह से वैरिएबल
ग्लोबल स्कोप शामिल है, भले ही किसी फ़ंक्शन या ब्लॉक में शुरू किया गया हो. वैरिएबल
जो इस पैटर्न का इस्तेमाल करके बनाई जाती हैं उन्हें कभी-कभी "लागू ग्लोबल" कहा जाता है.
function myFunction() {
globalVariable = "global";
return globalVariable
}
myFunction()\
> "global"
globalVariable\
> "global"
वैरिएबल को बढ़ाना
वैरिएबल और फ़ंक्शन एलानों को उनके स्कोप के सबसे ऊपर छोड़ा जाता है,
इसका मतलब है कि JavaScript इंटरप्रेटर किसी
पॉइंट करके, उसे इसके एनक्लोज़िंग की पहली लाइन में असरदार तरीके से ले जाता है
स्कोप के बाद कॉपी करें. इसका मतलब है कि किसी वैरिएबल का इस्तेमाल करके
वैरिएबल का एलान किए बिना, var
का रेफ़रंस दिया जा सकता है
गड़बड़ी:
hoistedVariable
> undefined
var hoistedVariable;
इसकी वजह यह है कि सिर्फ़ वैरिएबल की जानकारी को होस्ट किया गया है, न कि इनिशलाइज़ेशन को.
ऐसे वैरिएबल जिनके बारे में var
, let
या const
के साथ साफ़ तौर पर एलान नहीं किया गया है
ये विज्ञापन नहीं दिखाए जाते:
unhoistedVariable;
> Uncaught ReferenceError: unhoistedVariable is not defined
unhoistedVariable = true;
जैसा कि पहले बताया गया था, एक एलान किया गया, लेकिन शुरू नहीं किया गया वैरिएबल
को undefined
मान असाइन किया गया है. यह व्यवहार, होस्टेड वैरिएबल पर लागू होता है
एलानों के लिए भी उपलब्ध है. हालांकि, यह सिर्फ़ उन एलानों के लिए है जिनका एलान var
का इस्तेमाल करके किया गया है.
hoistedVariable
> undefined
var hoistedVariable = 2 + 2;
hoistedVariable\
> 4
यह साधारण व्यवहार काफ़ी हद तक डिज़ाइन से जुड़े फ़ैसलों की वजह से सबसे पुराने वर्शन में हैं, और जिन्हें खतरे के जोखिम के बिना बदला नहीं जा सकता नुकसान पहुंचा सकता है.
let
और const
इस व्यवहार को ठीक करने के लिए, गड़बड़ी की सूचना देते हैं. ऐसा तब होता है, जब
वैरिएबल को बनाने से पहले उसे ऐक्सेस किया जा सकता है:
{
hoistedVariable;
let hoistedVariable;
}
> Uncaught ReferenceError: can't access lexical declaration 'hoistedVariable' before initialization
यह गड़बड़ी "hoistedVariable तय नहीं किया गया है" से अलग है गड़बड़ी करो
किसी अघोषित वैरिएबल को ऐक्सेस करने पर यह उम्मीद कर सकती है. क्योंकि JavaScript
ने वैरिएबल को उठा लिया है, तो इसे पता है कि वैरिएबल को
दिया गया दायरा. हालांकि, उस वैरिएबल को इसके पहले उपलब्ध कराने के बजाय
undefined
की वैल्यू के साथ एलान करने पर, अनुवादक को गड़बड़ी मिलती है.
let
या const
(या class
) के साथ तय किए गए वैरिएबल
"टेंपोरल डेड ज़ोन" ("TDZ") से नाम की शुरुआत से लेकर,
उस कोड में पॉइंट करें जहां वैरिएबल का एलान किया गया है.
टेम्पोरल डेड ज़ोन var
की तुलना में let
के व्यवहार को ज़्यादा सहज बनाता है
लेखक. यह const
के डिज़ाइन के लिए भी अहम है. क्योंकि कॉन्सटेंट
बदल गया है, कॉन्सटैंट को अपने दायरे के शीर्ष पर ले जाया जाता है और एक इंप्लिसिट वैल्यू दी जाती है
इसलिए, undefined
को सही वैल्यू के साथ शुरू नहीं किया जा सकता.
देखें कि आपको कितना समझ आया है
आइडेंटिफ़ायर की शुरुआत किस तरह के वर्णों से की जा सकती है?
ऐसे वैरिएबल का एलान करने का पसंदीदा तरीका कौनसा है जिसका मान को किसी भी समय बदला जा सकता है?