टाइपस्क्रिप्ट - ऑब्जेक्ट

एक objectएक उदाहरण है जिसमें मुख्य मूल्य जोड़े के सेट शामिल हैं। मान स्केलर मान या फ़ंक्शन या अन्य ऑब्जेक्ट्स की सरणी भी हो सकते हैं। सिंटैक्स नीचे दिया गया है -

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

var object_name = { 
   key1: “value1”, //scalar value 
   key2: “value”,  
   key3: function() {
      //functions 
   }, 
   key4:[“content1”, “content2”] //collection  
};

जैसा कि ऊपर दिखाया गया है, एक ऑब्जेक्ट में स्केलर मान, फ़ंक्शंस और संरचनाएं जैसे सरणियाँ और ट्यूपल्स हो सकते हैं।

उदाहरण: ऑब्जेक्ट लिटरेचर नोटेशन

var person = { 
   firstname:"Tom", 
   lastname:"Hanks" 
}; 
//access the object values 
console.log(person.firstname) 
console.log(person.lastname)

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

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

Tom 
Hanks

टाइपस्क्रिप्ट टाइप टेम्पलेट

मान लीजिए कि आपने जावास्क्रिप्ट में एक वस्तु शाब्दिक रूप से बनाया है -

var person = { 
   firstname:"Tom", 
   lastname:"Hanks" 
};

यदि आप किसी वस्तु में कुछ मूल्य जोड़ना चाहते हैं, तो जावास्क्रिप्ट आपको आवश्यक संशोधन करने की अनुमति देता है। मान लें कि हमें व्यक्ति ऑब्जेक्ट में एक फ़ंक्शन जोड़ने की आवश्यकता है बाद में यह वह तरीका है जिससे आप ऐसा कर सकते हैं।

person.sayHello = function(){ return "hello";}

यदि आप टाइपस्क्रिप्ट में समान कोड का उपयोग करते हैं तो कंपाइलर एक त्रुटि देता है। ऐसा इसलिए है क्योंकि टाइपस्क्रिप्ट में, ठोस वस्तुओं में एक प्रकार का टेम्पलेट होना चाहिए। टाइपस्क्रिप्ट की वस्तुएँ एक विशेष प्रकार की एक आवृत्ति होनी चाहिए।

आप घोषणा में विधि टेम्पलेट का उपयोग करके इसे हल कर सकते हैं।

उदाहरण: टाइपस्क्रिप्ट टाइप टेम्पलेट

var person = {
   firstName:"Tom", 
   lastName:"Hanks", 
   sayHello:function() {  }  //Type template 
} 
person.sayHello = function() {  
   console.log("hello "+person.firstName)
}  
person.sayHello()

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

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

hello Tom

कार्य करने के लिए ऑब्जेक्ट्स को पैरामीटर के रूप में भी पास किया जा सकता है।

उदाहरण: फ़ंक्शन पैरामीटर के रूप में ऑब्जेक्ट

var person = { 
   firstname:"Tom", 
   lastname:"Hanks" 
}; 
var invokeperson = function(obj: { firstname:string, lastname :string }) { 
   console.log("first name :"+obj.firstname) 
   console.log("last name :"+obj.lastname) 
} 
invokeperson(person)

उदाहरण एक वस्तु शाब्दिक घोषित करता है। फंक्शन एक्सप्रेशन को पासिंग पर्सन ऑब्जेक्ट कहा जाता है।

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

//Generated by typescript 1.8.10
var person = {
   firstname: "Tom",
   lastname: "Hanks"
};

var invokeperson = function (obj) {
   console.log("first name :" + obj.firstname);
   console.log("last name :" + obj.lastname);
};

invokeperson(person);

इसका आउटपुट निम्नानुसार है -

first name :Tom 
last name :Hanks

आप मक्खी पर एक अनाम वस्तु बना सकते हैं और पास कर सकते हैं।

उदाहरण: बेनामी वस्तु

var invokeperson = function(obj:{ firstname:string, lastname :string}) { 
   console.log("first name :"+obj.firstname) 
   console.log("last name :"+obj.lastname) 
} 
invokeperson({firstname:"Sachin",lastname:"Tendulkar"});

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

//Generated by typescript 1.8.10
var invokeperson = function (obj) {
   console.log("first name :" + obj.firstname);
   console.log("last name :" + obj.lastname);
};

invokeperson({ firstname: "Sachin", lastname: "Tendulkar" });
invokeperson({ firstname: "Sachin", lastname: "Tendulkar" });

इसका आउटपुट निम्नानुसार है -

first name :Sachin 
last name :Tendulkar

बतख टाइपिंग

बत्तख-टाइपिंग में, दो वस्तुओं को एक ही प्रकार का माना जाता है यदि दोनों समान गुणों के सेट को साझा करते हैं। बतख-टाइपिंग उनकी उपयुक्तता की जांच करने के लिए, उनके वास्तविक प्रकार के बजाय, वस्तुओं में कुछ गुणों की उपस्थिति की पुष्टि करता है। अवधारणा को आम तौर पर निम्नलिखित वाक्यांश द्वारा समझाया गया है -

"जब मैं एक पक्षी को देखता हूं जो बतख की तरह चलता है और बतख की तरह तैरता है और बतख की तरह झपटता है, तो मैं उस पक्षी को बतख कहता हूं।"

टाइपस्क्रिप्ट कंपाइलर बतख-टाइपिंग प्रणाली को लागू करता है जो प्रकार की सुरक्षा को ध्यान में रखते हुए मक्खी पर ऑब्जेक्ट निर्माण की अनुमति देता है। निम्नलिखित उदाहरण से पता चलता है कि हम उन वस्तुओं को कैसे पारित कर सकते हैं जो एक इंटरफ़ेस को स्पष्ट रूप से लागू नहीं करते हैं, लेकिन एक फ़ंक्शन में सभी आवश्यक सदस्य होते हैं।

उदाहरण

interface IPoint { 
   x:number 
   y:number 
} 
function addPoints(p1:IPoint,p2:IPoint):IPoint { 
   var x = p1.x + p2.x 
   var y = p1.y + p2.y 
   return {x:x,y:y} 
} 

//Valid 
var newPoint = addPoints({x:3,y:4},{x:5,y:1})  

//Error 
var newPoint2 = addPoints({x:1},{x:4,y:3})