你们 typescript 用自带枚举还是字符串枚举,感觉字符串枚举类型用起来有点不可靠啊

158 天前
 june4

比如:

type InputType = 'text' | 'number'
let e: InputType | undefined = 'text'
const getHtmlStr = (t: InputType | undefined) => `${t === 'text' ? 'type=text' : '...'}`

我给枚举来个重命名吧,把 'text' 改成 'text2',下面用到的地方全都没有改过来,要手动改。

2262 次点击
所在节点    TypeScript
10 条回复
xuld
158 天前
使用“枚举”还是“字符串联合类型”,关键看目的是强调类型还是强调值。

1. 枚举需要记忆枚举的名字,不需要记忆具体有哪些项(因为可以点出来
2. 字符串联合需要记忆具体的内容,且内容和程序逻辑有密切关系

至于你说的重命名没有自动改过来,这只是实现的一个差异,未来可能会被抹平,但不应该为了这点差异而影响用谁的决策
DOLLOR
158 天前
用 object as const 。

还有最新的 TS 5.8 推出了 erasableSyntaxOnly 开关,会禁用 enmu 语法,我觉得淘汰 enum 可能是大势所趋了。
june4
158 天前
@xuld 枚举也不用记名字啊,vscode 参数补全可以弹出来枚举名字并在第一位,用起来和字符串没多大差别。而字符串到处传来传去心里不踏实,总得会丢掉枚举的类型约束,肉眼也看不出来。
june4
158 天前
@DOLLOR enum 要废弃确实有点不爽,ts 应该把 enum 关键字和 object as const 来个缝合,把 enum 当成 object as const 的纯语法糖而不是生成新结构。
liuw666
158 天前
字符串改起来费劲。用枚举和对象都行吧
june4
158 天前
@liuw666 可是对象不受 ts 特殊加持对待,没有枚举完美。比如
const Direction = {
Up : 'up',
Down: 'down',
Left: 'left',
Right: 'right',
} as const
type Direction = typeof Direction[keyof typeof Direction]

你要用到 Direction 类型的时候,补全不象 enum 一样让你知道这里要填个 Direction.xxx ,而是直接是字符串 'up', 'down'之类的,很容易让人误用。
jsq2627
158 天前
感觉大多数开源库倾向用字符串
Immortal
158 天前
typescript 自带的枚举都是不推荐用的,也会在将来废弃
可以看看这个文章
https://blog.disintegrator.dev/posts/ode-to-typescript-enums/
lisongeee
157 天前
# 6

感觉用 Symbol 的欲望不是很高?
chenliangngng
157 天前
我也有这个疑问,ts 对对象字面量和枚举支持不好,很难用,虽然 enum 不符合 ts 的初衷,但是转换成对象确实可以解决枚举的问题,否则所有枚举的地方都要声明两次

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

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

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

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

© 2021 V2EX