TS中的枚举是什么如何使用

在 TypeScript 中,枚举(enum)是一种用于定义命名常量集合的数据类型。枚举可以提高代码的可读性和可维护性,因为它允许开发人员定义并使用有意义的符号名称来表示特定的常量。

下面是一个使用枚举的示例:

typescript 复制代码
enum Color {
  Red = 1,
  Green = 2,
  Blue = 4
}

let color: Color = Color.Green;
console.log(color); // 输出 2

let colorName: string = Color[4];
console.log(colorName); // 输出 "Blue"

该示例定义了一个名为 Color 的枚举,其中包含了三个常量:RedGreenBlue。每个常量都有一个对应的数字值。在代码中,我们使用枚举类型 Color 来声明 color 变量,并将其赋值为 Color.Green。我们还使用 Color[4] 来获取枚举值为 4 的常量的名称(即 "Blue")。

在上面的示例中,枚举常量的值是自动分配的,但是你可以手动分配值,如下所示:

typescript 复制代码
enum Animal {
  Dog = 1,
  Cat = 3,
  Bird = 5
}

在手动分配值的情况下,枚举的常量必须是数字类型。如果某个常量没有手动分配值,则它的值将自动递增。

在 TypeScript 中,枚举的名称一般使用单数形式。枚举常量的名称通常使用大写字母和下划线,以便更好地区分常量和变量。

相关推荐
To_OC34 分钟前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC42 分钟前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
天渺工作室1 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny2 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi2 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒2 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__3 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒6 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569156 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔8 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js