ईएस 6 - चर

variable, परिभाषा के अनुसार, "मेमोरी में एक नामित स्थान" है जो मूल्यों को संग्रहीत करता है। दूसरे शब्दों में, यह एक कार्यक्रम में मूल्यों के लिए एक कंटेनर के रूप में कार्य करता है। चर नाम कहलाते हैंidentifiers। एक पहचानकर्ता के नामकरण नियम निम्नलिखित हैं -

  • पहचानकर्ता कीवर्ड नहीं हो सकते।

  • पहचानकर्ताओं में अक्षर और संख्या हो सकती है।

  • पहचानकर्ता में अंडरस्कोर (_) और डॉलर ($) चिह्न को छोड़कर स्थान और विशेष वर्ण नहीं हो सकते।

  • परिवर्तनीय नाम एक संख्या से शुरू नहीं हो सकते हैं।

सिंटैक्स टाइप करें

इसका उपयोग करने से पहले एक चर घोषित किया जाना चाहिए। ES5 सिंटैक्स का उपयोग कियाvarकीवर्ड समान प्राप्त करने के लिए। एक चर घोषित करने के लिए ES5 सिंटैक्स निम्नानुसार है।

//Declaration using var keyword 
var  variable_name

ES6 निम्नलिखित चर घोषणा सिंटैक्स का परिचय देता है -

  • का उपयोग करते हुए।
  • कास्ट का उपयोग करना।

Variable initializationचर में मान को संग्रहीत करने की प्रक्रिया को संदर्भित करता है। एक चर या तो इसकी घोषणा के समय या बाद के समय में शुरू किया जा सकता है।

वैरिएबल घोषित करने और आरंभ करने के लिए पारंपरिक ES5 प्रकार का सिंटैक्स निम्नानुसार है -

//Declaration using var keyword 
var variable_name = value

उदाहरण: चर का उपयोग करना

var name = "Tom" 
console.log("The value in the variable is: "+name)

उपरोक्त उदाहरण एक चर घोषित करता है और इसके मूल्य को प्रिंट करता है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

The value in the variable is Tom

जावास्क्रिप्ट और गतिशील टाइपिंग

जावास्क्रिप्ट एक गैर-टाइप भाषा है। इसका मतलब है कि जावास्क्रिप्ट चर किसी भी डेटा प्रकार का मान रख सकता है। कई अन्य भाषाओं के विपरीत, आपको चर घोषणा के दौरान जावास्क्रिप्ट को यह बताने की जरूरत नहीं है कि चर किस प्रकार का मूल्य रखेगा। किसी प्रोग्राम के निष्पादन के दौरान एक वैरिएबल का मान बदल सकता है और जावास्क्रिप्ट स्वचालित रूप से इसकी देखभाल करता है। इस सुविधा को कहा जाता हैdynamic typing

जावास्क्रिप्टयोग्य स्कोप

एक चर का दायरा आपके कार्यक्रम का क्षेत्र है जिसमें इसे परिभाषित किया गया है। परंपरागत रूप से, जावास्क्रिप्ट केवल दो स्कोपों ​​को परिभाषित करता है-वैश्विक और स्थानीय।

  • Global Scope - वैश्विक दायरे वाले एक चर को जावास्क्रिप्ट कोड के किसी भी हिस्से के भीतर से एक्सेस किया जा सकता है।

  • Local Scope - एक स्थानीय क्षेत्र के साथ एक चर एक समारोह के भीतर से पहुँचा जा सकता है जहाँ यह घोषित किया जाता है।

उदाहरण: वैश्विक बनाम स्थानीय चर

निम्न उदाहरण नाम से दो चर घोषित करता है num - एक फंक्शन (ग्लोबल स्कोप) के बाहर और दूसरा फंक्शन (लोकल स्कोप) के भीतर।

var num = 10 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) 
} 
console.log("value of num outside test() "+num) 
test()

चर जब फ़ंक्शन के भीतर संदर्भित होता है, तो स्थानीय रूप से स्कोप किए गए चर का मान प्रदर्शित करता है। हालांकि, चरnum जब फ़ंक्शन के बाहर एक्सेस किया जाता है, तो वैश्विक रूप से स्कोप की गई आवृत्ति वापस आती है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

value of num outside test() 10
value of num in test() 100

ES6 एक नया चर क्षेत्र परिभाषित करता है - ब्लॉक गुंजाइश।

द लेट एंड ब्लॉक स्कोप

ब्लॉक स्कोप एक वैरिएबल की पहुंच को उस ब्लॉक तक पहुंचाता है जिसमें यह घोषित किया गया है। varकीवर्ड वेरिएबल को फंक्शन स्कोप प्रदान करता है। वर कीवर्ड के विपरीत,let कीवर्ड स्क्रिप्ट को वैरिएबल तक पहुँच को निकटतम एन्क्लोज़िंग ब्लॉक तक सीमित रखने की अनुमति देता है।

"use strict" 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) { 
      console.log("Inner Block begins") 
      let num = 200 
      console.log("value of num : "+num)  
   } 
} 
test()

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

Note - सख्त मोड जावास्क्रिप्ट के प्रतिबंधित संस्करण में चुनने का एक तरीका है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

value of num in test() 100 
Inner Block begins 
value of num : 200

उदाहरण: चलो v / s var

var no = 10; 
var no = 20; 
console.log(no);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

20

हमें उसी कोड का उपयोग करके फिर से लिखना चाहिए let कीवर्ड।

let no = 10; 
let no = 20; 
console.log(no);

उपरोक्त कोड एक त्रुटि फेंक देगा: पहचानकर्ता 'नहीं' पहले ही घोषित किया जा चुका है। लेटर कीवर्ड का उपयोग करके घोषित किसी भी चर को ब्लॉक स्कोप सौंपा गया है।

चलो और ब्लॉक स्तर की सुरक्षा

अगर हम घोषणा करने की कोशिश करते हैं letएक ही ब्लॉक के भीतर दो बार चर, यह एक त्रुटि फेंक देंगे। निम्नलिखित उदाहरण पर विचार करें -

<script>
   let balance = 5000 // number type
   console.log(typeof balance)
   let balance = {message:"hello"} // changing number to object type
   console.log(typeof balance)
</script>

उपरोक्त कोड के परिणामस्वरूप निम्न त्रुटि होगी -

Uncaught SyntaxError: Identifier 'balance' has already been declared

चलो और कई ब्लॉक

हालाँकि, वही let चर का उपयोग किसी भी सिंटैक्स त्रुटियों के बिना विभिन्न ब्लॉक स्तर के स्कोप में किया जा सकता है।

उदाहरण

<script>
   let count = 100
   for (let count = 1;count <= 10;count++){
      //inside for loop brackets ,count value starts from 1
      console.log("count value inside loop is ",count);
   }
   //outside for loop brackets ,count value is 100
   console.log("count value after loop is",count);

   if(count == 100){
      //inside if brackets ,count value is 50
      let count = 50;
      console.log("count inside if block",count);
   }
   console.log(count);
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

count value inside loop is 1
count value inside loop is 2
count value inside loop is 3
count value inside loop is 4
count value inside loop is 5
count value inside loop is 6
count value inside loop is 7
count value inside loop is 8
count value inside loop is 9
count value inside loop is 10
count value after loop is 100
count inside if block 50
100

कास्ट

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

निम्नलिखित नियमों का उपयोग कर घोषित एक चर के लिए सही है const कीवर्ड -

  • स्थिरांक को फिर से असाइन नहीं किया जा सकता है।
  • एक स्थिरांक फिर से घोषित नहीं किया जा सकता है।
  • एक स्थिरांक को इनिशियलाइज़र की आवश्यकता होती है। इसका अर्थ यह है कि इसकी घोषणा के दौरान स्थिरांक को प्रारंभिक रूप दिया जाना चाहिए।
  • में निर्दिष्ट मान const परिवर्तनशील है।

उदाहरण

const x = 10
x = 12 // will result in an error!!

उपरोक्त कोड एक त्रुटि लौटाएगा क्योंकि स्थिरांक को मान पुन: असाइन नहीं किया जा सकता है। स्थिरांक चर अपरिवर्तनीय हैं।

स्थिरांक अपरिवर्तनीय हैं

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

<script>
   let income = 100000
   const INTEREST_RATE = 0.08
   income += 50000 // mutable
   console.log("changed income value is ",income)
   INTEREST_RATE += 0.01
   console.log("changed rate is ",INTEREST_RATE) //Error: not mutable
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

changed income value is 150000
Uncaught TypeError: Assignment to constant variable

कास्ट और सरणियाँ

निम्नलिखित उदाहरण से पता चलता है कि कैसे एक अपरिवर्तनीय सरणी बनाई जाती है। नए तत्वों को सरणी में जोड़ा जा सकता है। हालाँकि, सरणी को पुनर्संरचना में परिणाम के रूप में नीचे दिखाया गया है -

<script>
   const DEPT_NOS = [10,20,30,50]
   DEPT_NOS.push(40)
   console.log('dept numbers is ',DEPT_NOS)

   const EMP_IDS = [1001,1002,1003]
   console.log('employee ids',EMP_IDS)
   //re assigning variable employee ids
   EMP_IDS = [2001,2002,2003]
   console.log('employee ids after changing',EMP_IDS)
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

dept numbers is (5) [10, 20, 30, 50, 40]
employee ids (3) [1001, 1002, 1003]
Uncaught TypeError: Assignment to constant variable.

वार कीवर्ड

ईएस 6 से पहले, ए varकीवर्ड का उपयोग जावास्क्रिप्ट में एक चर घोषित करने के लिए किया गया था। चर का उपयोग कर की घोषणा कीvarब्लॉक स्तर की गुंजाइश का समर्थन नहीं करते। इसका मतलब है कि अगर एक चर एक लूप में घोषित किया गया है याif block यह लूप के बाहर पहुँचा जा सकता है या if block। इसका कारण यह है चर का उपयोग कर की घोषणा कीvar कीवर्ड समर्थन उत्थापन।

var और उत्थापन

Variable hoistingघोषित होने से पहले ही जावास्क्रिप्ट प्रोग्राम में वैरिएबल के उपयोग की अनुमति देता है। इस तरह के चरों को आरंभीकृत किया जाएगाundefinedडिफ़ॉल्ट रूप से। जावास्क्रिप्ट रनटाइम चर घोषणाओं के लिए स्कैन करेगा और उन्हें फ़ंक्शन या स्क्रिप्ट के शीर्ष पर रखेगा। चर के साथ घोषितvarकीवर्ड शीर्ष पर फहराया जाता है। निम्नलिखित उदाहरण पर विचार करें -

<script>
   variable company is hoisted to top , var company = undefined
   console.log(company); // using variable before declaring
   var company = "TutorialsPoint"; // declare and initialized here
   console.log(company);
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

undefined
TutorialsPoint

var और ब्लॉक स्कोप

block scopeजिस खंड में यह घोषित किया गया है, उसके लिए चर की पहुंच को प्रतिबंधित करता है। varकीवर्ड वेरिएबल को फंक्शन स्कोप प्रदान करता है। चर का उपयोग कर की घोषणा कीvarकीवर्ड में ब्लॉक स्कोप नहीं है। निम्नलिखित उदाहरण पर विचार करें -

<script>
   //hoisted to top ; var i = undefined
   for (var i = 1;i <= 5;i++){
      console.log(i);
   }
   console.log("after the loop i value is "+i);
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

1
2
3
4
5
after the loop i value is 6

चर i का उपयोग कर पाश के लिए अंदर घोषित किया गया है varकीवर्ड। चर मैं पाश के बाहर सुलभ है। हालाँकि, कई बार, किसी ब्लॉक के भीतर वैरिएबल की पहुंच को प्रतिबंधित करने की आवश्यकता हो सकती है। हम उपयोग नहीं कर सकतेvarइस परिदृश्य में कीवर्ड। ES6 परिचयlet इस सीमा को पार करने के लिए खोजशब्द।

var और ब्लॉक स्तर की सुरक्षा

अगर हम ऐसा ही घोषित करते हैं variable दो बार का उपयोग कर var keywordएक ब्लॉक के भीतर, संकलक एक त्रुटि नहीं करेगा। हालाँकि, इससे रनटाइम पर अनपेक्षित तार्किक त्रुटियाँ हो सकती हैं।

<script>
   var balance = 5000
   console.log(typeof balance)
   var balance = {message:"hello"}
   console.log(typeof balance)
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

number
object