关于Typescript中的类型别名

类型别名

在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)
}

看完上边的例子,相信你已经知道类型别名的作用了:它可以有助于我们减少重复输入复杂类型,还可以更加清楚地表明变量的作用

相关推荐
小村儿14 分钟前
连载10-Sub-agents 深度解析:从源码理解 Claude Code 的分身术
前端·后端·ai编程
IT_陈寒1 小时前
Vite动态导入把我坑惨了,原来要这样用才对
前端·人工智能·后端
DFT计算杂谈1 小时前
KPROJ编译教程
java·前端·python·算法·conda
觅_1 小时前
前端学习后端的时候 选择一个技术
前端·学习
独泪了无痕1 小时前
CryptoJS:数据安全的JavaScript加密利器
前端·vue.js·node.js
发现一只大呆瓜1 小时前
一文搞懂 Vite 处理CommonJS包、按需编译逻辑及 Rollup 插件兼容规则
前端
Edwardwu1 小时前
写了个y-mxgraph:给 draw.io 接上了 Yjs,顺便解决了部署在 iframe 里的一堆问题
前端·typescript
其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码
java·前端·网络·安全·网络安全·web·工具
发现一只大呆瓜2 小时前
Vite 开发预构建机制详解,搞懂 esbuild 与 Rollup 分工差异
前端·面试·vite
阿正的梦工坊3 小时前
【Typescript】14-高级实战-设计类型安全的-api
typescript