टाइपस्क्रिप्ट - एंबियंस

परिवेशी घोषणाएं टाइपस्क्रिप्ट कंपाइलर को यह बताने का एक तरीका है कि वास्तविक स्रोत कोड कहीं और मौजूद है। जब आप थर्ड पार्टी का एक गुच्छा खा रहे होते हैंjsलाइब्रेरी जैसे jquery / angularjs / नोडज आप इसे टाइपस्क्रिप्ट में फिर से नहीं लिख सकते हैं। इन पुस्तकालयों का उपयोग करते समय टाइपफैटी और इंटेलीसिस को सुनिश्चित करना टाइपस्क्रिप्ट प्रोग्रामर के लिए चुनौतीपूर्ण होगा। परिवेशी घोषणाएँ मूल रूप से अन्य को एकीकृत करने में मदद करती हैंjs टाइपस्क्रिप्ट में लाइब्रेरी।

परिभाषित करने वाले ग्राहक

निम्नलिखित घोषणाओं के साथ एक प्रकार की घोषणा फ़ाइल में रखे गए सम्मेलन द्वारा महत्वाकांक्षी घोषणाएँ होती हैं (d.ts)

Sample.d.ts

उपरोक्त फ़ाइल को जावास्क्रिप्ट में स्थानांतरित नहीं किया जाएगा। इसका इस्तेमाल टाइप सेफ्टी और इन्टेलिसेंस के लिए किया जाएगा।

परिवेश चर या मॉड्यूल घोषित करने का सिंटैक्स निम्नानुसार होगा -

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

declare module Module_Name {
}

परिवेशी फ़ाइलों को क्लाइंट टाइपस्क्रिप्ट फ़ाइल में दर्शाया जाना चाहिए -

/// <reference path = " Sample.d.ts" />

उदाहरण

आइए इसे एक उदाहरण की मदद से समझते हैं। मान लें कि आपको एक तृतीय पक्ष जावास्क्रिप्ट लाइब्रेरी दी गई है, जिसमें इसी के समान कोड है।

FileName: CalcThirdPartyJsLib.js 
var TutorialPoint;  
(function (TutorialPoint) {  
   var Calc = (function () { 
      function Calc() { 
      } 
      Calc.prototype.doSum = function (limit) {
         var sum = 0; 
         
         for (var i = 0; i <= limit; i++) { 
            Calc.prototype.doSum = function (limit) {
               var sum = 0; 
               
               for (var i = 0; i <= limit; i++) { 
                  sum = sum + i; 
                  return sum; 
                  return Calc; 
                  TutorialPoint.Calc = Calc; 
               })(TutorialPoint || (TutorialPoint = {})); 
               var test = new TutorialPoint.Calc();
            }
         }
      }
   }
}

टाइपस्क्रिप्ट प्रोग्रामर के रूप में आपके पास टाइप करने के लिए इस लाइब्रेरी को फिर से लिखने का समय नहीं होगा। लेकिन फिर भी आपको टाइप सुरक्षा के साथ doSum () विधि का उपयोग करने की आवश्यकता है। आप क्या कर सकते हैं परिवेश घोषणा फ़ाइल है। आइए हम एक मुख्य घोषणापत्र फ़ाइल Calc.d.ts बनाते हैं

FileName: Calc.d.ts 
declare module TutorialPoint { 
   export class Calc { 
      doSum(limit:number) : number; 
   }
}

परिवेशी फ़ाइलों में कार्यान्वयन नहीं होगा, यह केवल प्रकार की घोषणाएँ हैं। घोषणाओं को अब निम्नानुसार टाइपस्क्रिप्ट फ़ाइल में शामिल करने की आवश्यकता है।

FileName : CalcTest.ts  
/// <reference path = "Calc.d.ts" /> 
var obj = new TutorialPoint.Calc(); 
obj.doSum("Hello"); // compiler error 
console.log(obj.doSum(10));

कोड की निम्नलिखित पंक्ति एक संकलक त्रुटि दिखाएगी। ऐसा इसलिए है क्योंकि डिक्लेरेशन फ़ाइल में हमने निर्दिष्ट किया है कि इनपुट पैरामीटर नंबर होगा।

obj.doSum("Hello");

उपरोक्त पंक्ति पर टिप्पणी करें और निम्नलिखित सिंटैक्स का उपयोग करके कार्यक्रम संकलित करें -

tsc CalcTest.ts

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

//Generated by typescript 1.8.10
/// <reference path = "Calc.d.ts" />
var obj = new TutorialPoint.Calc();

// obj.doSum("Hello");
console.log(obj.doSum(10));

कोड को निष्पादित करने के लिए, नीचे दिए गए स्क्रिप्ट स्क्रिप्ट टैग के साथ एक html पृष्ठ जोड़ें। संकलित CalcTest.js फ़ाइल और तृतीय पक्ष लाइब्रेरी फ़ाइल CalcThirdPartyJsLib.js में जोड़ें।

<html> 
   <body style = "font-size:30px;"> 
      <h1>Ambient Test</h1> 
      <h2>Calc Test</h2> 
   </body> 
   
   <script src = "CalcThirdPartyJsLib.js"></script> 
   <script src = "CalcTest.js"></script> 
</html>

यह निम्न पृष्ठ प्रदर्शित करेगा -

कंसोल पर, आप निम्न आउटपुट देख सकते हैं -

55

इसी तरह, आप अपनी आवश्यकता के आधार पर jquery.d.ts या angular.d.ts को एक परियोजना में एकीकृत कर सकते हैं।