TypeScript 入门教程: 接口
ts接口相关
接口
在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型。
- implement: 在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类(classes)去实现(implement)。
- shape: TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。
// 任意属性
interface Person {
name: string;
age?: number;
[key: string]: any;
}
// 只读属性
interface Person {
readonly id: number;
name: string;
age?: number;
[propName: string]: any;
}
函数的合并
function reverse(x: number): number;
function reverse(x: string): string;
function reverse(x: number | string): number | string {
if (typeof x === 'number') {
return Number(x.toString().split('').reverse().join(''));
} else if (typeof x === 'string') {
return x.split('').reverse().join('');
}
}
接口合并
- 不同的key 会直接 merge
- 相同的key,如果类型一致就没事
- 相同的key,如果类型不一致就会报错j
interface Alarm {
price: number;
}
interface Alarm {
weight: number;
}
// --- 类型一致,虽然重复,但不会报错
interface Alarm {
price: number;
}
interface Alarm {
price: number; // 虽然重复了,但是类型都是 `number`,所以不会报错
weight: number;
}
带函数的合并
interface Alarm {
price: number;
alert(s: string): string;
}
interface Alarm {
weight: number;
alert(s: string, n: number): string;
}
// ---- 相当于以下结果
interface Alarm {
price: number;
weight: number;
alert(s: string): string;
alert(s: string, n: number): string;
}