टाइपस्क्रिप्ट - नाम स्थान

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

एक नाम स्थान परिभाषित करना

कीवर्ड के साथ नाम स्थान की परिभाषा शुरू होती है namespace इसके बाद नामस्थान नाम इस प्रकार है -

namespace SomeNameSpaceName { 
   export interface ISomeInterfaceName {      }  
   export class SomeClassName {      }  
}

जिन कक्षाओं या इंटरफेस को नाम स्थान के बाहर एक्सेस किया जाना चाहिए, उन्हें कीवर्ड के साथ चिह्नित किया जाना चाहिए export

किसी अन्य नामस्थान में वर्ग या इंटरफ़ेस तक पहुंचने के लिए, सिंटैक्स नामस्थान होगा .className

SomeNameSpaceName.SomeClassName;

यदि पहला नाम स्थान अलग टाइपस्क्रिप्ट फ़ाइल में है, तो इसे ट्रिपल स्लैश संदर्भ सिंटैक्स का उपयोग करके संदर्भित किया जाना चाहिए।

/// <reference path = "SomeFileName.ts" />

निम्नलिखित कार्यक्रम नेमस्पेस के उपयोग को प्रदर्शित करता है -

FileName :IShape.ts 
---------- 
namespace Drawing { 
   export interface IShape { 
      draw(); 
   }
}  

FileName :Circle.ts 
---------- 
/// <reference path = "IShape.ts" /> 
namespace Drawing { 
   export class Circle implements IShape { 
      public draw() { 
         console.log("Circle is drawn"); 
      }  
      
      FileName :Triangle.ts 
      ---------- 
      /// <reference path = "IShape.ts" /> 
      namespace Drawing { 
         export class Triangle implements IShape { 
            public draw() { 
               console.log("Triangle is drawn"); 
            } 
         } 
         
         FileName : TestShape.ts 
         /// <reference path = "IShape.ts" />   
         /// <reference path = "Circle.ts" /> 
         /// <reference path = "Triangle.ts" />  
         function drawAllShapes(shape:Drawing.IShape) { 
            shape.draw(); 
         } 
         drawAllShapes(new Drawing.Circle());
         drawAllShapes(new Drawing.Triangle());
      }
   }
}

उपरोक्त कोड को निम्नलिखित कमांड का उपयोग करके संकलित और निष्पादित किया जा सकता है -

tsc --out app.js TestShape.ts  

node app.js

संकलन करने पर, यह जावास्क्रिप्ट कोड (app.js) के बाद उत्पन्न होगा।

//Generated by typescript 1.8.10
/// <reference path = "IShape.ts" />
var Drawing;
(function (Drawing) {
   var Circle = (function () {
      function Circle() {
      }
      Circle.prototype.draw = function () {
         console.log("Cirlce is drawn");
      };
      return Circle;
   }());
	
   Drawing.Circle = Circle;
})(Drawing || (Drawing = {}));

/// <reference path = "IShape.ts" />
var Drawing;
(function (Drawing) {
   var Triangle = (function () {
      function Triangle() {
      }
      Triangle.prototype.draw = function () {
         console.log("Triangle is drawn");
      };
      return Triangle;
   }());
   Drawing.Triangle = Triangle;
})(Drawing || (Drawing = {}));

/// <reference path = "IShape.ts" />
/// <reference path = "Circle.ts" />
/// <reference path = "Triangle.ts" />
function drawAllShapes(shape) {
   shape.draw();
}

drawAllShapes(new Drawing.Circle());
drawAllShapes(new Drawing.Triangle());

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Circle is drawn 
Triangle is drawn

नेस्टेड नेमस्पेस

आप एक नामस्थान को दूसरे नामस्थान के अंदर परिभाषित कर सकते हैं -

namespace namespace_name1 { 
   export namespace namespace_name2 {
      export class class_name {    } 
   } 
}

आप निम्नांकित नाम स्थान के सदस्यों को निम्नानुसार डॉट (।) ऑपरेटर का उपयोग करके देख सकते हैं -

FileName : Invoice.ts  
namespace tutorialPoint { 
   export namespace invoiceApp { 
      export class Invoice { 
         public calculateDiscount(price: number) { 
            return price * .40; 
         } 
      } 
   } 
} 
FileName: InvoiceTest.ts 

/// <reference path = "Invoice.ts" />
var invoice = new tutorialPoint.invoiceApp.Invoice(); 
console.log(invoice.calculateDiscount(500));

उपरोक्त कोड को निम्नलिखित कमांड का उपयोग करके संकलित और निष्पादित किया जा सकता है -

tsc --out app.js InvoiceTest.ts 
node app.js

संकलन करने पर, यह जावास्क्रिप्ट कोड (app.js) के बाद उत्पन्न होगा।

//Generated by typescript 1.8.10
var tutorialPoint;
(function (tutorialPoint) {
   var invoiceApp;
   (function (invoiceApp) {
      var Invoice = (function () {
         function Invoice() {
         }
         Invoice.prototype.calculateDiscount = function (price) {
            return price * .40;
         };
         return Invoice;
      }());
      invoiceApp.Invoice = Invoice;
   })(invoiceApp = tutorialPoint.invoiceApp || (tutorialPoint.invoiceApp = {}));
	
})(tutorialPoint || (tutorialPoint = {}));
/// <reference path = "Invoice.ts" />

var invoice = new tutorialPoint.invoiceApp.Invoice();
console.log(invoice.calculateDiscount(500));

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

200