接口(interface)是一系列抽象属性和方法的集合声明,这些方法都应该是抽象的,需要由具体的类去实现,然后外界就可以通过这组抽象方法调用,让具体的类执行具体的方法。
**接口的作用在开发中针对的是数据对象和类的结构进行描述和规范化。**说白了,就是你老大叫你声明一个类/对象,但是这个类/对象长什么样?他会以接口的格式先定义好,然后你照着这个接口定义好的格式进行编写一个类/对象出来,免得你弄乱结构,以后没法复用代码。
一般只有在中大型项目,或者框架/大型模块中为了更好的组织代码结构才会出现抽象类/接口
定义接口
nterface PayTool {
SERVER_URL:string;
pay: ()=>string;
}
class Alipay implements PayTool{
SERVER_URL:string;
constructor(server_url:string){
this.SERVER_URL = server_url
}
pay(){
return "ok"
}
}
class WechatPay implements PayTool{
SERVER_URL:string;
constructor(server_url:string){
this.SERVER_URL = server_url;
}
pay(){
return "ok"
}
}
var alipay = new Alipay("http://api.alipay.com");
console.log(alipay);
console.log( alipay.pay() );
接口的简写实现
nterface Person {
username: string;
age: number;
desc():string
}
function main(person: Person) {
return "Hello, 我叫" + person.username + ",我今年" + person.age+"岁.";
}
// typescript允许直通过对象来直接实现接口,跳过了类的实现过程
// var 对象名 = <接口名称>{
// 属性;
// 方法;
// }
let user = <Person>{
username: "小白",
age: 16,
desc(){
return "hello"
}
};
console.log(main(user));
// js就是披着面向对象外壳的函数式编程语言
鸭子类型
在传递实例参数时,不管当前传入的实例参数是否是限定的类/接口的实例对象,只要有同样的属性/方法,那么我们就认为当前实例参数就是这个限定类/接口的实例对象。这就是所谓的鸭子类型。
python中的鸭子类型
class Person(object):
def __init__(self,username,age):
self.username = username
self.age = age
class Humen(object):
def __init__(self,username,age):
self.username = username
self.age = age
def main(obj:Person):
return "我叫%s,我今年%s岁了" % (obj.username,obj.age)
if __name__ == '__main__':
p1 = Person("小明", 15)
p2 = Humen("小白", 15)
print( main(p2) )
接口继承
单继承
interface Person {
age:number
}
interface Humen extends Person {
username:string
desc(user:string):string
}
class People implements Humen{
age:number;
username:string;
constructor(username,age){
this.age = age;
this.username=username;
}
desc(user:string):string{
return `${user},您好!我叫${this.username},我今年${this.age}岁.`
}
}
var xm = new People("小明",15);
console.log( xm.desc("小红") );
多继承
interface Person {
age:number
}
interface Humen{
username:string
desc(user:string):string
}
// 可以同时实现多个接口
class People implements Person, Humen{
age:number;
username:string;
constructor(username,age){
this.age = age;
this.username=username;
}
desc(user:string):string{
return `${user},您好!我叫${this.username},我今年${this.age}岁.`
}
}
var xm = new People("小明",15);
console.log( xm.desc("小红") );