类型别名概述
类型别名就是给一个类型起个
新名字
, 但是它们都代表同一个类型
例如: 你的本名叫张三, 你的外号叫小三, 小三就是张三的别名, 张三和小三都表示同一个人
type MyString = string; let value: MyString; value = 'abc'; value = 123; value = false;
如上代码的含义为给 string 类型起了一个别名叫做 MyString
, 那么将来无论是 MyString 还是 string 都表示 string
也就是说将来你使用 MyString
别名作为变量的类型那么改变量就只能存储字符串类型的数据像如上的示例代码我赋值了其它类型的数据其实在编译器当中已经报错了如下:
类型别名也可以使用
泛型
type MyType<T> = { x: T, y: T }; let value: MyType<number>; value = {x: 123, y: 456}; value = {x: '123', y: 456}; value = {x: false, y: 456};
如上代码的含义为,定义了一个对象泛型别名,该对象当中有两个属性 x、y, 然后定义了一个该别名的变量,泛型类型指定的为 number 那么就不能在存储其它类型的值,如上代码有部分是报错的,如下:
可以在类型别名类型的属性中使用自己 一般用于定义一些
树状结构
或者嵌套结构
的数据结构
type MyType = { name: string, children?: MyType } let value: MyType = { name: 'one', children: { name: 'one', children: { name: 'one', } } }
如上代码当中使用到了可选参数不然会一直循环的定义下去。
接口和类型别名是相互兼容的
type MyType = { name: string } interface MyInterface { name: string } let value1: MyType = {name: 'yangbuyiya'}; let value2: MyInterface = {name: 'zs'}; value1 = value2; value2 = value1;
接口和类型别名的异同
都可以描述
属性
或方法
type MyType = { name: string; say(): void; } interface MyInterface { name: string; say(): void; }
都允许
扩展
interface:
interface MyInterface { name: string; say(): void; } interface MyInterface2 extends MyInterface { age: number; } let value: MyInterface2 = { name: 'yangbuyiya', age: 18, say(): void { } }
type 利用一个 &
来实现扩展:
type MyType = { name: string; say(): void; } type MyType2 = MyType & { age: number; } let value: MyType2 = { name: 'yangbuyiya', age: 18, say(): void { } }
不同点
type 可以声明
基本类型
别名,联合类型
,元组
等类型,interface
不能
type MyType1 = boolean; type MyType2 = string | number; type MyType3 = [string, boolean, number];
type 不会自动合并
interface 的自动合并可查看 TypeScript 当中的 30.TypeScript-接口合并现象 这里就只演示 type 的不会自动合并的不同点:
type MyType = { name: string } type MyType = { age: number }
最后
本期结束咱们下次再见👋~
🌊 关注我不迷路,如果本篇文章对你有所帮助,或者你有什么疑问,欢迎在评论区留言,我一般看到都会回复的。大家点赞支持一下哟~ 💗