声明合并
定义了两个相同名字的函数、接口或类,那么它们会合并成一个类型。
函数的合并
可以使用重载定义多个函数类型:
js
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('');
}
}
接口的合并
接口中的属性在合并时会简单的合并到一个接口中:
js
interface Alarm {
price: number;
}
interface Alarm {
weight: number;
}
// 等价于
interface Alarm {
price: number;
weight: number;
}
ps:合并的属性的类型和属性值必须是唯一的
js
interface Alarm {
price: number;
}
interface Alarm {
price: number; // 虽然重复了,但是类型都是 `number`,所以不会报错
weight: number;
}
interface Alarm {
price: number;
}
interface Alarm {
price: string; // 类型不一致,会报错
weight: number;
}
interface Cat {
name:"小橘"
}
interface Cat {
//编译报错
name:"小橘1";
age:3
}
接口中方法的合并,与函数的合并一样:
js
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;
}
类的合并
类的合并与接口的合并规则一致。