1. 基本类型兼容性:
TypeScript 中的基本类型是根据其结构进行比较的,而不是依赖于它们的名称。
let x: number = 1;
let y: number | string = 1;
x = y; // 兼容,因为 number 可以赋值给 number | string
// y = x; // 不兼容,因为 number | string 不能赋值给 number
2. 接口兼容性:
当一个类型具有至少与另一个类型相同的属性时,它们被认为是兼容的。
interface Point {
x: number;
y: number;
}
let point: Point = { x: 1, y: 2 };
let point2: { x: number; y: number; z: number } = point; // 兼容,因为 Point 的结构在 point2 中存在
3. 函数兼容性:
函数兼容性与参数和返回值的类型相关,兼容性要求目标函数的参数类型必须是源函数参数类型的子类型,而返回值类型必须是源函数返回值类型的超类型。
type Callback = (x: number, y: number) => number;
let cb1: Callback = (a, b) => a + b;
let cb2: (a: number, b: number, c: number) => number = cb1; // 兼容,因为 cb1 的参数和返回值类型是 cb2 的子集
4. 类兼容性:
类的兼容性与接口兼容性相似,当一个类具有至少与另一个类相同的实例属性时,它们被认为是兼容的。
class A {
x: number = 1;
y: number = 2;
}
class B {
x: number = 3;
}
let a: A = new B(); // 兼容,因为 B 的结构包含 A 的所有属性
5. 枚举兼容性:
枚举类型之间是不兼容的,除非它们的成员类型和数量完全一致。
enum Color { Red, Green, Blue }
enum Size { Small, Medium, Large }
let color: Color = Color.Red;
// color = Size.Small; // 不兼容,Color 和 Size 是不同的枚举类型
6. 泛型兼容性:
当使用泛型类型时,类型参数的具体类型并不影响类型兼容性。
interface Container<T> {
value: T;
}
let c1: Container<number> = { value: 42 };
let c2: Container<string> = c1; // 兼容,因为 Container<number> 和 Container<string> 结构相同
类型兼容性是 TypeScript 中的一个关键概念,它使得代码更加灵活,允许你在不破坏类型安全的前提下使用不同的类型。理解类型兼容性对于正确使用 TypeScript 的类型系统非常重要。
转载请注明出处:http://www.pingtaimeng.com/article/detail/4701/TypeScript