टाइपस्क्रिप्ट - ऑब्जेक्ट
एक 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})