栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

TypeScript学习之类型兼容性

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

TypeScript学习之类型兼容性

一、基础

Typescript里的类型兼容性是基于结构子类型的。
结构类型是一种只使用其成员来描述类型的方式
规则:如果x要兼容y,那么y至少具有与x相同的属性(x是y的子集)

interface Named {
  name: string;
}let x: Named;let y = { name: 'Alice', location: 'Seattle' };
x = y;
函数
//比较两个函数let x = (a: number) => 0;let y = (b: number, s: string) => 0;

y = x; // OKx = y; // Error
枚举

枚举类型与数字类型兼容,并且数字类型与枚举类型兼容。
不同枚举类型之间是不兼容的

enum Status { Ready, Waiting };enum Color { Red, Blue, Green };

let status = Status.Ready;
status = Color.Green;  //error

比较两个类类型的对象时,只有实例的成员会被比较。 静态成员和构造函数不在比较的范围内

class Animal {
  feet: number;  constructor(name: string, numFeet: number) { }
}class Size {
  feet: number;  constructor(numFeet: number) { }
}let a: Animal;let s: Size;

a = s;  //OKs = a;  //OK
类的私有成员

私有成员会影响兼容性判断。 当类的实例用来检查兼容时,如果目标类型包含一个私有成员,那么源类型必须包含来自同一个类的这个私有成员。 这允许子类赋值给父类,但是不能赋值给其它有同样类型的类。

泛型

对于没指定泛型类型的泛型参数时,会把所有泛型参数当成any比较

interface NotEmpty {
  data: T;
}
let x: NotEmpty;
let y: NotEmpty;

x = y;  // error, x and y are not compatible



作者:大富_大贵
链接:https://www.jianshu.com/p/1112a7de0491


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/247073.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号