ईएस 6 - मॉड्यूल

परिचय

एक परिदृश्य पर विचार करें जहां जावास्क्रिप्ट कोड के कुछ हिस्सों को पुन: उपयोग करने की आवश्यकता है। ES6 की अवधारणा के साथ अपने बचाव के लिए आता है Modules

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

एक मॉड्यूल का निर्यात

निर्यात कीवर्ड का उपयोग किसी मॉड्यूल में घटकों को निर्यात करने के लिए किया जा सकता है। एक मॉड्यूल में निर्यात निम्नानुसार वर्गीकृत किया जा सकता है -

  • नाम दिया गया निर्यात
  • डिफ़ॉल्ट निर्यात

नाम दिया गया निर्यात

नामांकित निर्यात उनके नाम से प्रतिष्ठित हैं। एक मॉड्यूल में कई नामित निर्यात हो सकते हैं। एक मॉड्यूल नीचे दिए गए सिंटैक्स का उपयोग करके चयनित घटकों को निर्यात कर सकता है -

Syntax 1

//using multiple export keyword
export component1
export component2
...
...
export componentN

Syntax 2

वैकल्पिक रूप से, एक मॉड्यूल में घटकों को एकल निर्यात कीवर्ड के साथ निर्यात किया जा सकता है, जो नीचे दिखाए गए अनुसार {} बाइंडिंग सिंटैक्स के साथ होता है -

//using single export keyword

export {component1,component2,....,componentN}

डिफ़ॉल्ट निर्यात

ऐसे मॉड्यूल जिन्हें केवल एक मूल्य का निर्यात करने की आवश्यकता होती है, वे डिफ़ॉल्ट निर्यात का उपयोग कर सकते हैं। प्रति मॉड्यूल केवल एक डिफ़ॉल्ट निर्यात हो सकता है।

Syntax

export default component_name

हालांकि, एक मॉड्यूल में एक ही समय में एक डिफ़ॉल्ट निर्यात और कई नामित निर्यात हो सकते हैं।

एक मॉड्यूल आयात करना

एक मॉड्यूल का उपभोग करने में सक्षम होने के लिए, का उपयोग करें import keyword। एक मॉड्यूल में कई हो सकते हैंimport statements

नामांकित निर्यात आयात करना

नामित निर्यात आयात करते समय, संबंधित घटकों के नाम मेल खाना चाहिए।

Syntax

import {component1,component2..componentN} from module_name

हालांकि, नामित निर्यात आयात करते समय, उन्हें कीवर्ड के रूप में नाम दिया जा सकता है। नीचे दिए गए वाक्यविन्यास का उपयोग करें -

import {original_component_name as new_component_name }

सभी नामित निर्यातों को तारांकन के उपयोग से किसी वस्तु पर आयात किया जा सकता है * operator

import * as variable_name from module_name

डिफ़ॉल्ट निर्यात आयात करना

नामित निर्यात के विपरीत, किसी भी नाम के साथ एक डिफ़ॉल्ट निर्यात आयात किया जा सकता है।

Syntax

import any_variable_name from module_name

उदाहरण: नामांकित निर्यात

Step 1 - एक फ़ाइल company1.js बनाएं और निम्नलिखित कोड जोड़ें -

let company = "TutorialsPoint"

let getCompany = function(){
   return company.toUpperCase()
}

let setCompany = function(newValue){
   company = newValue
}

export {company,getCompany,setCompany}

Step 2- एक फ़ाइल company2.js बनाएँ। यह फ़ाइल company1.js फ़ाइल में परिभाषित घटकों का उपभोग करती है। मॉड्यूल आयात करने के लिए निम्नलिखित में से किसी भी दृष्टिकोण का उपयोग करें।

Approach 1

import {company,getCompany} from './company1.js'

console.log(company)
console.log(getCompany())

Approach 2

import {company as x, getCompany as y} from './company1.js'

console.log(x)
console.log(y())

Approach 3

import * as myCompany from './company1.js'

console.log(myCompany.getCompany())
console.log(myCompany.company)

Step 3 - HTML फ़ाइल का उपयोग करके मॉड्यूल को निष्पादित करें

दोनों मॉड्यूल्स को निष्पादित करने के लिए हमें नीचे दिखाए अनुसार html फाइल बनाने की जरूरत है और इसे लाइव सर्वर में चलाएं। ध्यान दें कि हमें इसका उपयोग करना चाहिएattribute type="module" स्क्रिप्ट टैग में।

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>Document</title>
</head>
<body>
   <script src="./company2.js" type="module"></script>
</body>
</html>

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

TutorialsPoint
TUTORIALSPOINT

डिफ़ॉल्ट निर्यात

Step 1 - एक फ़ाइल बनाएँ company1.js और निम्नलिखित कोड जोड़ें -

let name = 'TutorialsPoint'

let company = {
   getName:function(){
      return name
   },
   setName:function(newName){
      name = newName
   }
}

export default company

Step 2 - एक फ़ाइल बनाएँ company2.js। यह फ़ाइल company1.js फ़ाइल में परिभाषित घटकों को खाती है।

import c from './company1.js'
console.log(c.getName())
c.setName('Google Inc')
console.log(c.getName())

Step 3 - निष्पादित करें modules का उपयोग कर HTML file

दोनों मॉड्यूल को निष्पादित करने के लिए हमें नीचे दिखाए गए अनुसार html फाइल बनाने की जरूरत है और इसे लाइव सर्वर में चलाएं। ध्यान दें कि हमें इसका उपयोग करना चाहिएattribute type="module" स्क्रिप्ट टैग में।

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>Document</title>
</head>
<body>
   <script src="./company2.js" type="module"></script>
</body>
</html>

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

TutorialsPoint
Google Inc

उदाहरण: डिफ़ॉल्ट और नामांकित एक्सपोर्ट्स को मिलाना

Step 1 - एक फ़ाइल बनाएँ company1.js और निम्नलिखित कोड जोड़ें -

//named export
export let name = 'TutorialsPoint'

let company = {
   getName:function(){
      return name
   },
   setName:function(newName){
      name =newName
   }
}
//default export
export default company

Step 2 - एक फ़ाइल बनाएँ company2.js। यह फ़ाइल में परिभाषित घटकों का उपभोग करती हैcompany1.jsफ़ाइल। पहले डिफ़ॉल्ट निर्यात आयात करें, उसके बाद नामित निर्यात।

import c, {name} from './company1.js'

console.log(name)
console.log(c.getName())
c.setName("Mohtashim")
console.log(c.getName())

Step 3 - HTML फ़ाइल का उपयोग करके मॉड्यूल को निष्पादित करें

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
   </head>
   <body>
      <script src="company2.js" type="module"></script>
   </body>
</html>

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

TutorialsPoint
TutorialsPoint
Mohtashim