🔧写了个前端维护枚举值的小工具

2023-03-16 08:52:32 +08:00
 paledream

x-enum

管理枚举值的工具

Github

动机

在业务中,我们经常需要维护一些枚举值,如状态、类型,这些枚举值包含 key: 唯一键(一般为英文)value: 值(对应后端存储的数据)label: 中文名(用于展示)

之前我会这样去维护这些枚举值:

export enum STATUS {
  // key -> value
  TODO = 1,
  PENDING = 2,
  DONE = 3,
}

export const STATUS_TEXT = {
  // key -> value -> label
  [STATUS.TODO]: "todo",
  [STATUS.PENDING]: "pending",
  [STATUS.DONE]: "done",
};

但是这样的维护方式有以下几个问题:

  1. STATUS_TEXT 的 key 被转为 string 而非 number, 需要转换
  2. 无法快速生成 Select 组件的 options
  3. 根据 value 取 label 比较繁琐,需要 STATUS_TEXT[STATUS.TODO]

因此我总结了 B 端场景下的以下这些常见使用场景:

  1. select 组件的 options: 一般为 { label: string; value: string | number }[] 这样的数据
  2. 根据 key 获取 value
  3. 根据 key 获取 label
  4. 根据 value 获取 label
  5. 根据 value 获取 key
  6. 获取所有的 key
  7. 获取所有的 value
  8. 获取所有的 label

该函数工具封装了以上业务场景的方法,方便维护枚举值,并且TS 支持 key 值的枚举推断

使用方式

install

npm i @xliez/x-enum
# or
yarn add @xliez/x-enum

# or
pnpm add @xliez/x-enum

example

import { Select } from "antd";
import { xEnum } from "@xliez/x-enum";

const TypeEnum = xEnum({
  TODO: [0, "待办"],
  PENDING: [1, "处理中"],
  DONE: [2, "已完成"],
});

// 1. 生成 select 组件 options
const App = () => {
  return (
    <>
      <Select label="select" name="select" options={TypeEnum.genOptions()} />
    </>
  );
};

// 2. 根据 key 取 value
const value = TypeEnum.TODO.value; // 支持 TS 推断
// or
const value = TypeEnum.valueByKey("TODO");

// 3. 根据 key 取 label
const label = TypeEnum.TODO.label; // 支持 TS 推断
// or
const label = TypeEnum.labelByKey("TODO");

// 4. 根据 value 取 label
const label = TypeEnum.labelByValue(0);

// 5. 根据 value 取 key
const key = TypeEnum.keyByValue(0);

// 6. 获取所有的 key
const keys = TypeEnum.keys;

// 7. 获取所有的 value
const values = TypeEnum.values;

// 8. 获取所有的 label
const labels = TypeEnum.labels;
2140 次点击
所在节点    分享创造
6 条回复
paledream
2023-03-16 09:32:16 +08:00
欢迎大家 star✨和反馈🐛
vaporSpace
2023-03-16 09:48:16 +08:00
我之前也写了类似的,但你设计的更好,如果需要这个枚举的 ts 类型要怎么搞呢
Trim21
2023-03-16 09:54:44 +08:00
你列出来的有几个功能是 ts 的 enum 原生支持的...

```ts
enum STATUS {
// key -> value
todo = 1,
pending = 2,
done = 3,
}

console.log(STATUS[STATUS.todo]);
console.log(STATUS['todo']);
console.log(STATUS);
```
paledream
2023-03-16 10:20:16 +08:00
@Trim21 是的,TS enum 的反向映射支持了 value -> key ,但也因为这个特性,key 和 value 实际都是 key ,所以无法使用类似 `Object.keys` 快速生成 Select options
paledream
2023-03-16 10:33:03 +08:00
@vaporSpace 是类似这样的类型支持吗

```ts
enum EmployeeStatus {
}

const F: EmployeeStatus = EmployeeStatus.xxx
```
目前还不支持,后续我思考下
Trim21
2023-03-16 14:15:06 +08:00
@paledream 可以参考下 https://github.com/sinclairzx81/typebox 的 type helper “Static”

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/924391

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX