类型别名
在JavaScript中,我们可以使用变量声明(let、const和var)为值声明别名,那么同样,在Typescript中,我们还可以为类型声明别名,例:
ts
type Age = number
type Person = {
name: string,
age: Age
}
Age就是一个number,这样可以让Person的结构定义更易于理解,Typescript无法推导类型别名,所以必须显示注解:
ts
let age: Age = 18
let xiaoniu: Person = {
name: 'Mars',
age: age
}
由于Age是number的别名,所以可以直接给number赋值
ts
let age = 18
let xiaoniu: Person = {
name: 'Mars',
age: age
}
如上,没有问题
不能重复声明同一类型
我们知道,在JavaScript中,let/const不能两次声明同一个变量,var两次声明同一个变量时,虽然并不会报错,但也只是对值进行了覆盖。那么在Typescript中同一个类型也同样不能声明两次:
ts
type Color = 'red'
type Color = 'blue' // 标识符"Color"重复
此时移动光标可以发现编辑器报出的警告
作用域
在JavaScript中let、const采用的是块级作用域,类似地,类型别名采用的也是块级作用域。每一块代码和每一个函数都有自己的作用域,内部的类型别名将遮盖外部的类型别名:
ts
type Color = 'red'
let x = Math.random() < .5
// 和let和const一样,类型别名使用的是块级作用域
if (x) {
type Color = 'blue'
let b: Color = 'blue'
// console.log(x, b)
} else {
let c: Color = 'red'
// console.log(x, c)
}
看完上边的例子,相信你已经知道类型别名的作用了:它可以有助于我们减少重复输入复杂类型,还可以更加清楚地表明变量的作用