टाइपस्क्रिप्ट - इंटरफेस
एक इंटरफ़ेस एक संविदात्मक अनुबंध है जो एक इकाई के अनुरूप होना चाहिए। दूसरे शब्दों में, एक इंटरफ़ेस वाक्यविन्यास को परिभाषित करता है जिसे किसी भी इकाई को पालन करना होगा।
इंटरफेस गुणों, विधियों और घटनाओं को परिभाषित करते हैं, जो इंटरफ़ेस के सदस्य हैं। इंटरफेस में केवल सदस्यों की घोषणा शामिल है। यह व्युत्पन्न वर्ग की जिम्मेदारी है कि वह सदस्यों को परिभाषित करे। यह अक्सर एक मानक संरचना प्रदान करने में मदद करता है जो व्युत्पन्न वर्ग का पालन करेगा।
आइए एक वस्तु पर विचार करें -
var person = {
FirstName:"Tom",
LastName:"Hanks",
sayHi: ()=>{ return "Hi"}
};
यदि हम वस्तु के हस्ताक्षर पर विचार करते हैं, तो यह हो सकता है -
{
FirstName:string,
LastName:string,
sayHi()=>string
}
वस्तुओं पर हस्ताक्षर का पुन: उपयोग करने के लिए हम इसे एक इंटरफ़ेस के रूप में परिभाषित कर सकते हैं।
घोषणाओं में कमी
इंटरफ़ेस कीवर्ड का उपयोग इंटरफ़ेस घोषित करने के लिए किया जाता है। यहाँ एक इंटरफ़ेस घोषित करने के लिए वाक्यविन्यास है -
वाक्य - विन्यास
interface interface_name {
}
उदाहरण: इंटरफ़ेस और ऑब्जेक्ट
interface IPerson {
firstName:string,
lastName:string,
sayHi: ()=>string
}
var customer:IPerson = {
firstName:"Tom",
lastName:"Hanks",
sayHi: ():string =>{return "Hi there"}
}
console.log("Customer Object ")
console.log(customer.firstName)
console.log(customer.lastName)
console.log(customer.sayHi())
var employee:IPerson = {
firstName:"Jim",
lastName:"Blakes",
sayHi: ():string =>{return "Hello!!!"}
}
console.log("Employee Object ")
console.log(employee.firstName);
console.log(employee.lastName);
उदाहरण एक इंटरफ़ेस को परिभाषित करता है। ग्राहक वस्तु IPerson प्रकार की है। इसलिए, यह अब इंटरफ़ेस द्वारा निर्दिष्ट सभी गुणों को परिभाषित करने के लिए ऑब्जेक्ट पर बाध्यकारी होगा।
निम्नलिखित हस्ताक्षर के साथ एक अन्य वस्तु, अभी भी IPerson के रूप में मानी जाती है क्योंकि उस वस्तु का उपचार उसके आकार या हस्ताक्षर द्वारा किया जाता है।
संकलन करने पर, यह जावास्क्रिप्ट कोड के बाद उत्पन्न होगा।
//Generated by typescript 1.8.10
var customer = { firstName: "Tom", lastName: "Hanks",
sayHi: function () { return "Hi there"; }
};
console.log("Customer Object ");
console.log(customer.firstName);
console.log(customer.lastName);
console.log(customer.sayHi());
var employee = { firstName: "Jim", lastName: "Blakes",
sayHi: function () { return "Hello!!!"; } };
console.log("Employee Object ");
console.log(employee.firstName);
console.log(employee.lastName);
उपरोक्त उदाहरण कोड का आउटपुट निम्नानुसार है -
Customer object
Tom
Hanks
Hi there
Employee object
Jim
Blakes
Hello!!!
इंटरफेस को जावास्क्रिप्ट में परिवर्तित नहीं किया जाना है। यह टाइपस्क्रिप्ट का सिर्फ एक हिस्सा है। यदि आप टीएस प्लेग्राउंड टूल का स्क्रीन शॉट देखते हैं तो क्लास के विपरीत इंटरफ़ेस घोषित करने पर कोई जावा स्क्रिप्ट उत्सर्जित नहीं होती है। तो इंटरफेस में शून्य रनटाइम जावास्क्रिप्ट प्रभाव होता है।
यूनियन प्रकार और इंटरफ़ेस
निम्नलिखित उदाहरण संघ प्रकार और इंटरफ़ेस का उपयोग दिखाता है -
interface RunOptions {
program:string;
commandline:string[]|string|(()=>string);
}
//commandline as string
var options:RunOptions = {program:"test1",commandline:"Hello"};
console.log(options.commandline)
//commandline as a string array
options = {program:"test1",commandline:["Hello","World"]};
console.log(options.commandline[0]);
console.log(options.commandline[1]);
//commandline as a function expression
options = {program:"test1",commandline:()=>{return "**Hello World**";}};
var fn:any = options.commandline;
console.log(fn());
संकलन करने पर, यह जावास्क्रिप्ट कोड के बाद उत्पन्न होगा।
//Generated by typescript 1.8.10
//commandline as string
var options = { program: "test1", commandline: "Hello" };
console.log(options.commandline);
//commandline as a string array
options = { program: "test1", commandline: ["Hello", "World"] };
console.log(options.commandline[0]);
console.log(options.commandline[1]);
//commandline as a function expression
options = { program: "test1", commandline: function () { return "**Hello World**"; } };
var fn = options.commandline;
console.log(fn());
इसका उत्पादन निम्नानुसार है -
Hello
Hello
World
**Hello World**
इंटरफेस और एरेज़
इंटरफ़ेस एक प्रकार की कुंजी का उपयोग करता है और उसमें प्रवेश के प्रकार दोनों को परिभाषित कर सकता है। इंडेक्स टाइप स्ट्रिंग या टाइप नंबर का हो सकता है।
उदाहरण
interface namelist {
[index:number]:string
}
var list2:namelist = ["John",1,"Bran"] //Error. 1 is not type string
interface ages {
[index:string]:number
}
var agelist:ages;
agelist["John"] = 15 // Ok
agelist[2] = "nine" // Error
इंटरफेस और वंशानुक्रम
एक इंटरफेस अन्य इंटरफेस द्वारा बढ़ाया जा सकता है। दूसरे शब्दों में, एक इंटरफ़ेस अन्य इंटरफ़ेस से इनहेरिट कर सकता है। टाइपस्क्रिप्ट एक इंटरफ़ेस को कई इंटरफेस से विरासत में प्राप्त करने की अनुमति देता है।
इंटरफ़ेस का उपयोग करें इंटरफेस के बीच विरासत को लागू करने के लिए।
सिंटेक्स: सिंगल इंटरफ़ेस इनहेरिटेंस
Child_interface_name extends super_interface_name
सिंटेक्स: मल्टीपल इंटरफ़ेस इनहेरिटेंस
Child_interface_name extends super_interface1_name,
super_interface2_name,…,super_interfaceN_name
उदाहरण: सरल इंटरफ़ेस वंशानुक्रम
interface Person {
age:number
}
interface Musician extends Person {
instrument:string
}
var drummer = <Musician>{};
drummer.age = 27
drummer.instrument = "Drums"
console.log("Age: "+drummer.age) console.log("Instrument: "+drummer.instrument)
संकलन करने पर, यह जावास्क्रिप्ट कोड के बाद उत्पन्न होगा।
//Generated by typescript 1.8.10
var drummer = {};
drummer.age = 27;
drummer.instrument = "Drums";
console.log("Age: " + drummer.age);
console.log("Instrument: " + drummer.instrument);
इसका उत्पादन निम्नानुसार है -
Age: 27
Instrument: Drums
उदाहरण: एकाधिक इंटरफ़ेस वंशानुक्रम
interface IParent1 {
v1:number
}
interface IParent2 {
v2:number
}
interface Child extends IParent1, IParent2 { }
var Iobj:Child = { v1:12, v2:23}
console.log("value 1: "+this.v1+" value 2: "+this.v2)
ऑब्जेक्ट Iobj इंटरफ़ेस इंटरफ़ेस पत्ती का है। वंशानुक्रम के आधार पर इंटरफेस लीफ में अब दो विशेषताएँ हैं- क्रमशः v1 और v2। इसलिए, ऑब्जेक्ट Iobj में अब ये विशेषताएँ होनी चाहिए।
संकलन करने पर, यह जावास्क्रिप्ट कोड के बाद उत्पन्न होगा।
//Generated by typescript 1.8.10
var Iobj = { v1: 12, v2: 23 };
console.log("value 1: " + this.v1 + " value 2: " + this.v2);
उपरोक्त कोड का आउटपुट निम्नानुसार है -
value 1: 12 value 2: 23