【TypeScript】TypeScript的接口和对象类型(interface):
创始人
2024-05-26 09:21:50

文章目录

        • 一、使用接口约束的时候不能多一个属性也不能少一个属
        • 二、重名interface 可以合并,继承
        • 三、可选属性 使用?操作符
        • 四、任意属性 [propName: string]
        • 五、只读属性 readonly,是不允许被赋值的只能读取
        • 六、添加函数


一、使用接口约束的时候不能多一个属性也不能少一个属

//这样写是会报错的 因为我们在person定义了a,b但是对象里面缺少b属性
//使用接口约束的时候不能多一个属性也不能少一个属性
//必须与接口保持一致
interface Person {b:string,a:string
}const person:Person  = {a:"213"
}

二、重名interface 可以合并,继承

//重名interface  可以合并
interface A{name:string}
interface A{age:number}
var x:A={name:'xx',age:20
}//继承
interface A{name:string
}interface B extends A{age:number
}let obj:B = {age:18,name:"string"
}

三、可选属性 使用?操作符

//可选属性的含义是该属性可以不存在
//所以说这样写也是没问题的
interface Person {b?:string,a:string
}const person:Person  = {a:"213"
}

四、任意属性 [propName: string]

需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集:

//在这个例子当中我们看到接口中并没有定义C但是并没有报错
//应为我们定义了[propName: string]: any;
//允许添加新的任意属性
interface Person {b?:string,a:string,[propName: string]: any;
}const person:Person  = {a:"213",c:"123"
}

五、只读属性 readonly,是不允许被赋值的只能读取

//这样写是会报错的
//应为a是只读的不允许重新赋值
interface Person {b?: string,readonly a: string,[propName: string]: any;
}const person: Person = {a: "213",c: "123"
}person.a = 123

六、添加函数

interface Person {b?: string,readonly a: string,[propName: string]: any;cb:()=>void
}const person: Person = {a: "213",c: "123",cb:()=>{console.log(123)}
}

相关内容

热门资讯

1小时就卖光!不够卖!南通地铁... (来源:江海晚报)吕四鲳鱼泛着银光真空包装的海蜇透着脆嫩圆滚滚的芋艿裹着泥土清香…… 今天(6日)上...
白宫发布新版《国家安全战略》,... (来源:都市现场)美国白宫于当地时间4日晚发布特朗普政府的新版《国家安全战略》。这份文件共33页,阐...
北京、兴安盟携手绘新图景:山海... 中新网兴安盟12月6日电 题:北京、兴安盟携手绘新图景:山海同心育桃李中新网记者 张玮曾几何时,优质...
行进的海岸线|陆海统筹 看中国... 来源:央广网央广网北京12月5日消息 海风掠过漫长海岸线,吹起一道又一道正在崛起的海洋产业带。日前,...
加沙地带媒体办公室:加沙燃气供... 转自:央视据加沙地带媒体办公室当地时间6日消息,自今年加沙停火协议生效以来,加沙地带燃气供应严重不足...