टाइपस्क्रिप्ट - इंटरफेस

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

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

आइए एक वस्तु पर विचार करें -

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