因为JS语言不慎过于领过, 真实开发场景中往往无法做到严格一致的类型约束,此时TS就不得不做类型兼容
子集可以赋值给父级
type name = string | number
string 和 number 都是 类型name 的子集
属性多的可以赋值给属性少的,前提是有共同属性
1 2 3 4 5 6 7 8 9 10 |
type Person = { name: string age: number } let user = { name: 'liu', age: 20, email: '' } let p: Person = user |
数量少的兼容数量多的,前提为类型一致
只要参数部分能够找到对应的位置就用**==绿色箭头==,否则为==红色箭头==**,当参数全为绿色箭头时,最左侧的箭头就为绿色,代表函数可以兼容
参数部分: 子类可以兼容父类,则函数整体不能兼容,
MyMouseEvent 是 MyEvent 的子类,所以mouseListener 不兼容 listener
==对参数要求多的函数不能赋值给对参数要求少的函数==
MyEvent 是 MyMouseEvent 的父类,所以listener 兼容 mouseListener
返回值属性多集合小 可以 兼容 返回值属性少集合大