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
相关推荐
炫饭第一名1 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫1 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊1 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter1 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折2 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_2 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
Angelial2 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu2 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端
jiayu2 小时前
Angular6学习笔记13:HTTP(3)
前端
小码哥_常3 小时前
Kotlin抽象类与接口:相爱相杀的编程“CP”
前端