TypeScript 中如何转换两个具有相同值的枚举类型?

在 TypeScript 中,我们有时会遇到两个不同名称但具有相同值的枚举类型(enum)。例如:

ini 复制代码
enum EnumA {
  Red = 'Red',
  Green = 'Green',
  Blue = 'Blue'
}

enum EnumB {
  Red = 'Red',
  Green = 'Green',
  Blue = 'Blue'
}

那么,该如何在 EnumAEnumB 之间进行转换呢?下面介绍几种常见方法:

方法一:类型断言(Type Assertion)

这是最简单直接的方式:

ini 复制代码
const a: EnumA = EnumA.Red;
const b: EnumB = a as EnumB;

只要两个枚举值完全一致,这种方式是可行的,但缺乏类型安全。


方法二:显式转换函数(推荐)

为了提高代码的可读性和安全性,推荐使用一个封装好的转换函数:

arduino 复制代码
function convertEnumAtoEnumB(a: EnumA): EnumB {
  switch (a) {
    case EnumA.Red:
      return EnumB.Red;
    case EnumA.Green:
      return EnumB.Green;
    case EnumA.Blue:
      return EnumB.Blue;
  }
}

这种方式便于维护,如果将来两个枚举的值发生变化,也可以快速定位问题。


方法三:基于值的动态映射

如果枚举值是字符串或数字且完全一致,也可以通过值来映射:

ini 复制代码
const a: EnumA = EnumA.Green;
const b: EnumB = EnumB[a as keyof typeof EnumB];

或者使用一个通用的转换函数:

typescript 复制代码
function convertEnumValue<T extends string, U>(value: T, targetEnum: Record<T, U>): U {
  return targetEnum[value];
}

const b = convertEnumValue(a, EnumB); // b 是 EnumB.Green
相关推荐
掘金01几秒前
EmbedPDF Vue 版 完整正文文档 全网首发
前端
OpenTiny社区2 分钟前
操作ArkTS页面跳转及路由相关心得
前端·typescript·web·opentiny
xiaohua0708day3 分钟前
Lodash库
前端·javascript·vue.js
huakoh3 分钟前
Claude Code 从零到上手指南:国产工具链复现80% Agent能力,DeepSeek+LangChain实战
前端
Ankkaya5 分钟前
浏览器插件接入 Google 登录
前端
Asmewill7 分钟前
DeepAgents学习笔记一(构建深度多智能体)
前端
万物皆对象6668 分钟前
切换路由时页面空白问题(vue3)
前端·vue.js·typescript
突然好热8 分钟前
TS 调试技巧
前端·javascript·typescript
h64648564h9 分钟前
Flutter 国际化(i18n)全指南:一键切换中/英/日多语言
前端·javascript·flutter
令人头秃的代码0_010 分钟前
AI时代下,如何做原子代码拆分
前端