解释 TypeScript 中的枚举(enum),如何使用枚举定义一组常量?

news2025/3/18 6:28:54

枚举(Enum)​ 是 TypeScript 中用于定义一组具名常量的核心类型,通过语义化的命名提升代码可读性,同时利用类型检查减少低级错误。

以下从定义方式、使用建议、注意事项三方面深入解析。


一、枚举的定义方式

1. 数字枚举

特性:默认从 0 开始自增,支持手动赋值,支持反向映射(通过值获取键)

// 定义用户状态枚举
enum UserStatus {
  New,       // 0
  Active,    // 1
  Blocked,   // 2
  Deleted = 404 // 手动赋值
}

// 使用示例
const currentStatus: UserStatus = UserStatus.Active;
console.log(currentStatus); // 输出: 1
console.log(UserStatus[1]); // 反向映射输出: "Active"
2. 字符串枚举

特性:每个成员必须显式初始化,无反向映射,适用于需明确语义的场景

// 定义 API 端点枚举
enum ApiEndpoint {
  Login = "/api/login",
  UserInfo = "/api/user",
  Logout = "/api/logout"
}

// 使用示例
fetch(ApiEndpoint.Login) // 发起登录请求
  .then(response => { /*...*/ });
3. 异构枚举(混合类型)

慎用:混合数字和字符串成员,易导致维护问题

enum MixedEnum {
  A = 1,
  B = "B_VALUE",
  C = 2 // 允许但容易引发混乱
}
4. 常量枚举

特性:编译后完全移除,直接内联值,适用于性能敏感场景

const enum Direction {
  Up = "UP",
  Down = "DOWN"
}

// 编译后 Direction 消失,直接替换为 "UP"/"DOWN"
console.log(Direction.Up); // 输出: "UP"

二、使用建议

1. 优先字符串枚举

理由:避免数字枚举的“魔法值”问题,明确语义且无副作用

// 推荐:字符串枚举明确表示错误类型
enum ErrorType {
  Timeout = "TimeoutError",
  Network = "NetworkError"
}

// 不推荐:数字枚举需额外注释说明
enum LegacyError {
  Timeout, // 0-超时错误
  Network  // 1-网络错误
}
2. 避免数字枚举的陷阱

问题:隐式自增可能导致意外覆盖

enum Problematic {
  A = 2,
  B,    // 3(预期外)
  C = 1,
  D     // 2(覆盖 A)
}
3. 合理使用常量枚举

场景:高频访问且无需反射的常量,如状态码

const enum HttpCode {
  OK = 200,
  NotFound = 404
}

if (response.status === HttpCode.OK) { 
  // 编译后直接替换为数字
}
4. 避免过度使用枚举

替代方案:对象常量或联合类型

// 简单键值对场景用对象
const ROLES = {
  Admin: "admin",
  User: "user"
} as const;

// 有限集合用联合类型
type LogLevel = "debug" | "info" | "error";

三、注意事项

1. 初始化顺序依赖

问题:前置成员未初始化会导致引用错误

enum Cycle {
  A = B, // Error: B 未定义
  B = 1
}
2. 运行时存在性

常量枚举:编译后消失,无法通过 Object.keys() 遍历

// 常规枚举可遍历
console.log(Object.keys(UserStatus)); // ["0", "1", "2", "404", "New", ...]

// 常量枚举在运行时不存在
console.log(Direction.Up); // 有效
console.log(Direction);    // 编译错误
3. 模块化导出规范

建议:统一导出方式避免混乱

// 正确:显式导出
export enum Color { Red = "#FF0000" }

// 正确:统一通过 constants 模块管理
export const enum Sizes { Small = "S" }
4. 避免循环引用

陷阱:跨文件枚举相互引用导致未定义

// file1.ts
import { SecondEnum } from "./file2";
export enum FirstEnum { A = SecondEnum.B }

// file2.ts
import { FirstEnum } from "./file1";
export enum SecondEnum { B = FirstEnum.A } // 循环依赖报错

总结

合理使用枚举能显著提升代码质量,但需根据场景选择合适类型。字符串枚举推荐作为默认选择,常量枚举适合性能优化,数字枚举需警惕隐式赋值。

同时注意模块化管理和编译后行为,避免在复杂场景中引入维护负担。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2317057.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于SpringBoot+Vue的驾校预约管理系统+LW示例参考

1.项目介绍 系统角色:管理员、普通用户、教练功能模块:用户管理、管理员管理、教练管理、教练预约管理、车辆管理、车辆预约管理、论坛管理、基础数据管理等技术选型:SpringBoot,Vue等测试环境:idea2024,j…

ONNX:统一深度学习工作流的关键枢纽

引言 在深度学习领域,模型创建与部署的割裂曾是核心挑战。不同框架训练的模型难以在多样环境部署,而 ONNX(Open Neural Network Exchange)作为开放式神经网络交换格式,搭建起从模型创建到部署的统一桥梁,完…

蓝桥杯————23年省赛 ——————平方差

3.平方差 - 蓝桥云课 一开始看题我还没有意识到问题的严重性 我丢,我想 的是用两层循环来做,后来我试了一下最坏情况,也就是l1 r 1000000000 结果运行半天没运行出来,我就知道坏了,孩子们,要出事&#…

一、串行通信基础知识

一、串行通信基础知识 1.处理器与外部设备通信有两种方式 并行通信:数据的各个位用多条数据线同时传输。(传输速度快,但占用引脚资源多。) 串行通信:将数据分成一位一位的形式在一条数据线上逐个传输。(线路…

自带多个接口,完全免费使用!

做自媒体的小伙伴们,是不是经常为语音转文字的事儿头疼? 今天给大家推荐一款超实用的语音转文字软件——AsrTools,它绝对是你的得力助手! AsrTools 免费的语音转文字软件 这款软件特别贴心,完全免费,而且操…

Qt QML解决SVG图片显示模糊的问题

前言 在QML中直接使用SVG图片,使用Image控件加载资源,显示出来图片是模糊的,很影响使用体验。本文介绍重新绘制SVG图片,然后注册到QML中使用。 效果图: 左边是直接使用Image加载资源显示的效果 右边是重绘后的效果 …

【Linux我做主】基础命令完全指南上篇

Linux基础命令完全指南【上篇】 Linux基础命令完全指南github地址前言命令行操作的引入Linux文件系统树形结构的根文件系统绝对路径和相对路径适用场景Linux目录下的隐藏文件 基本指令目录和文件相关1. ls2. cd和pwdcdpwd 3. touch4. mkdir5. cp6. mv移动目录时覆盖写入的两种特…

Designing Dashboards with SAP Analytics Cloud

Designing Dashboards with SAP Analytics Cloud

项目实战系列:基于瑞萨RA6M5构建多节点OTA升级-系统设计<一>

项目背景 原嵌入式控制系统采用分布式模块化架构,由12个功能板卡(通信控制、信号采集、驱动执行等)组成。系统维护阶段存在以下痛点: 低效的本地烧录机制:各板卡固件升级需通过JTAG接口逐一手动连接JLINK仿真器&#x…

《AI大模型趣味实战》 No3:快速搭建一个漂亮的AI家庭网站-相册/时间线/日历/多用户/个性化配色/博客/聊天室/AI管家(下)

《AI大模型趣味实战》 No3:快速搭建一个漂亮的AI家庭网站-相册/时间线/日历/多用户/个性化配色/博客/聊天室/AI管家(下) 摘要 本文介绍了家庭网站V1.3版本的更新内容,主要聚焦于AI管家功能的优化与完善。V1.3版本对AI管家模块进行了全面升级&#xff0…

c++基础知识-图论进阶

一、拓扑排序 1、基础知识 1)什么是拓扑排序 对一个有向无环图G进行拓扑排序,是将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若,则u在线性序列中出现在v之前。 2)拓扑排序的操作方法 重复执行…

[Java实战]Spring Boot服务CPU 100%问题排查:从定位到解决

Spring Boot服务CPU 100%问题排查:从定位到解决 1. 引言 当Spring Boot服务出现CPU占用率100%时,系统性能会急剧下降,甚至导致服务不可用。本文将通过真实代码案例,详细讲解如何快速定位问题根源,并提供解决方案。无…

1.6 极限存在准则

1.夹逼定理(迫敛定理) 1.1 数列型 1.1.1 准则 1.2 函数型 2. 两个重要极限

大华SDK协议在智联视频超融合平台中的接入方法

一. 大华SDK协议详解 (一)、大华SDK协议概述 大华SDK(Software Development Kit)协议是大华股份为开发者提供的一套软件开发工具包,旨在帮助开发者快速集成大华设备(如摄像头、NVR、DVR等)的功…

卓越的用户体验需要智能内容

摘要:这篇文章指出静态文档已无法满足现代用户的需求,而智能内容则是构建卓越用户体验的关键。文章从智能内容的定义、优势和实际应用等方面进行了详细阐述,并强调了企业应积极拥抱智能内容,以提升客户满意度、降低成本并创造新的…

【蓝桥杯】1124修建公路1(Kruskal算法)

思路 找到能够连通所有城市的最小树即可,可用Prim或Kruscal。 !!注意,m的范围是包括0的,可就是包含没有道路的情况,要单独输出0 code import os import sys# 输入 n,m map(int,input().split()) road …

传感云揭秘:边缘计算的革新力量

在当今快速发展的科技时代,传感云和边缘计算系统正逐渐成为人们关注的焦点。传感云作为物联网与云计算的结合体,通过虚拟化技术将物理节点转化为多个服务节点,为用户提供高效、便捷的服务。而边缘计算则是一种靠近数据源头或物端的网络边缘侧…

Bigemap Pro 的三种地图下载方式

地图下载通常是是最基础但也最重要的任务之一,无论是进行空间分析、制作专题地图,还是进行数据可视化,高质量的地图数据都是不可或缺的。Bigemap Pro提供了三种地图下载方式,分别适用于不同的场景和需求。无论是免费版用户还是专业…

Python直方图:从核密度估计到高维空间解析

一、直方图的核心原理与数学本质 数据分布的视觉解码器 直方图(Histogram)是数据科学家的"分布显微镜",通过将连续数据划分为等宽区间(Bin),统计各区间的频数/频率,用相邻矩形条直观…