टाइपस्क्रिप्ट - मॉड्यूल

एक मॉड्यूल टाइपस्क्रिप्ट में लिखे गए कोड को व्यवस्थित करने के लिए विचार के साथ बनाया गया है। मॉड्यूल को मोटे तौर पर विभाजित किया गया है -

  • आंतरिक मॉड्यूल
  • बाहरी मॉड्यूल

आंतरिक मॉड्यूल

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

आंतरिक मॉड्यूल सिंटैक्स (पुराना)

module TutorialPoint { 
   export function add(x, y) {  
      console.log(x+y); 
   } 
}

नेमस्पेस सिंटेक्स (नया)

namespace TutorialPoint { 
   export function add(x, y) { console.log(x + y);} 
}

दोनों मामलों में उत्पन्न जावास्क्रिप्ट समान हैं

var TutorialPoint; 
(function (TutorialPoint) { 
   function add(x, y) { 
      console.log(x + y); 
   } 
   TutorialPoint.add = add; 
})(TutorialPoint || (TutorialPoint = {}));

बाहरी मॉड्यूल

टाइपस्क्रिप्ट में बाहरी मॉड्यूल कई बाहरी के बीच निर्भरता को निर्दिष्ट और लोड करने के लिए मौजूद हैं jsफ़ाइलें। अगर एक ही हैjsफ़ाइल का उपयोग किया गया, फिर बाहरी मॉड्यूल प्रासंगिक नहीं हैं। जावास्क्रिप्ट फ़ाइलों के बीच परंपरागत रूप से निर्भरता प्रबंधन ब्राउज़र स्क्रिप्ट टैग (<स्क्रिप्ट> </ स्क्रिप्ट>) का उपयोग करके किया गया था। लेकिन यह विस्तार योग्य नहीं है, क्योंकि मॉड्यूल लोड करते समय इसके बहुत रैखिक हैं। इसका मतलब है कि एक के बाद एक फाइलें लोड करने के बजाय मॉड्यूल लोड करने के लिए कोई अतुल्यकालिक विकल्प नहीं है। जब आप उदाहरण के लिए सर्वर के लिए js प्रोग्रामिंग कर रहे हैं NodeJs आप भी स्क्रिप्ट टैग नहीं है।

लोडिंग आश्रितों के लिए दो परिदृश्य हैं js एकल मुख्य जावास्क्रिप्ट फ़ाइल से फ़ाइलें।

  • क्लाइंट साइड - आवश्यकताएँ
  • सर्वर साइड - NodeJs

एक मॉड्यूल लोडर का चयन करना

बाहरी जावास्क्रिप्ट फ़ाइलों को लोड करने का समर्थन करने के लिए, हमें एक मॉड्यूल लोडर की आवश्यकता है। यह दूसरा होगाjsपुस्तकालय। ब्राउज़र के लिए उपयोग की जाने वाली सबसे आम लाइब्रेरी RequieJS है। यह AMD (अतुल्यकालिक मॉड्यूल परिभाषा) विनिर्देश का कार्यान्वयन है। एक के बाद एक फाइलें लोड करने के बजाय, एएमडी उन सभी को अलग-अलग लोड कर सकता है, भले ही वे एक दूसरे पर निर्भर हों।

बाह्य मॉड्यूल को परिभाषित करना

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

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

बाह्य मॉड्यूल घोषित करने के लिए वाक्यविन्यास कीवर्ड 'निर्यात' और 'आयात' का उपयोग कर रहा है।

वाक्य - विन्यास

//FileName : SomeInterface.ts 
export interface SomeInterface { 
   //code declarations 
}

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

import someInterfaceRef = require(“./SomeInterface”);

उदाहरण

आइए इसे एक उदाहरण का उपयोग करके समझते हैं।

// IShape.ts 
export interface IShape { 
   draw(); 
}

// Circle.ts 
import shape = require("./IShape"); 
export class Circle implements shape.IShape { 
   public draw() { 
      console.log("Cirlce is drawn (external module)"); 
   } 
} 

// Triangle.ts 
import shape = require("./IShape"); 
export class Triangle implements shape.IShape { 
   public draw() { 
      console.log("Triangle is drawn (external module)"); 
   } 
}
   
// TestShape.ts 
import shape = require("./IShape"); 
import circle = require("./Circle"); 
import triangle = require("./Triangle");  

function drawAllShapes(shapeToDraw: shape.IShape) {
   shapeToDraw.draw(); 
} 

drawAllShapes(new circle.Circle()); 
drawAllShapes(new triangle.Triangle());

AMD सिस्टम के लिए मुख्य टाइपस्क्रिप्ट फ़ाइल संकलित करने का कमांड है -

tsc --module amd TestShape.ts

संकलन करने पर, यह एएमडी के लिए जावास्क्रिप्ट कोड का पालन करेगा।

फ़ाइल: IShape.js

//Generated by typescript 1.8.10
define(["require", "exports"], function (require, exports) {
});

फ़ाइल: Circle.js

//Generated by typescript 1.8.10
define(["require", "exports"], function (require, exports) {
   var Circle = (function () {
      function Circle() {
      }
      Circle.prototype.draw = function () {
         console.log("Cirlce is drawn (external module)");
      };
      return Circle;
   })();
   exports.Circle = Circle;
});

फ़ाइल: Triangle.js

//Generated by typescript 1.8.10
define(["require", "exports"], function (require, exports) {
   var Triangle = (function () {
      function Triangle() {
      }
      Triangle.prototype.draw = function () {
         console.log("Triangle is drawn (external module)");
      };
      return Triangle;
   })();
   exports.Triangle = Triangle;
});

फ़ाइल: TestShape.js

//Generated by typescript 1.8.10
define(["require", "exports", "./Circle", "./Triangle"], 
   function (require, exports, circle, triangle) {
   
   function drawAllShapes(shapeToDraw) {
      shapeToDraw.draw();
   }
   drawAllShapes(new circle.Circle());
   drawAllShapes(new triangle.Triangle());
});

के लिए मुख्य टाइपस्क्रिप्ट फ़ाइल संकलित करने का आदेश Commonjs सिस्टम है

tsc --module commonjs TestShape.ts

संकलन करने पर, यह जावास्क्रिप्ट कोड निम्नलिखित के लिए उत्पन्न करेगा Commonjs

फ़ाइल: Circle.js

//Generated by typescript 1.8.10
var Circle = (function () {
   function Circle() {
   }
   Circle.prototype.draw = function () {
      console.log("Cirlce is drawn");
   };
   return Circle;
})();

exports.Circle = Circle;

फ़ाइल: Triangle.js

//Generated by typescript 1.8.10
var Triangle = (function () {
   function Triangle() {
   }
   Triangle.prototype.draw = function () {
      console.log("Triangle is drawn (external module)");
   };
   return Triangle;
})();
exports.Triangle = Triangle;

फ़ाइल: TestShape.js

//Generated by typescript 1.8.10
var circle = require("./Circle");
var triangle = require("./Triangle");

function drawAllShapes(shapeToDraw) {
   shapeToDraw.draw();
}
drawAllShapes(new circle.Circle());
drawAllShapes(new triangle.Triangle());

उत्पादन

Cirlce is drawn (external module)
Triangle is drawn (external module)