比如:

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

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

举报· 722 次点击
登录 注册 站外分享
6 条回复  
xuld 小成 3 天前
使用“枚举”还是“字符串联合类型”,关键看目的是强调类型还是强调值。 1. 枚举需要记忆枚举的名字,不需要记忆具体有哪些项(因为可以点出来 2. 字符串联合需要记忆具体的内容,且内容和程序逻辑有密切关系 至于你说的重命名没有自动改过来,这只是实现的一个差异,未来可能会被抹平,但不应该为了这点差异而影响用谁的决策
DOLLOR 小成 3 天前
用 object as const 。 还有最新的 TS 5.8 推出了 erasableSyntaxOnly 开关,会禁用 enmu 语法,我觉得淘汰 enum 可能是大势所趋了。
june4 楼主 小成 3 天前
@xuld 枚举也不用记名字啊,vscode 参数补全可以弹出来枚举名字并在第一位,用起来和字符串没多大差别。而字符串到处传来传去心里不踏实,总得会丢掉枚举的类型约束,肉眼也看不出来。
june4 楼主 小成 3 天前
@DOLLOR enum 要废弃确实有点不爽,ts 应该把 enum 关键字和 object as const 来个缝合,把 enum 当成 object as const 的纯语法糖而不是生成新结构。
liuw666 小成 3 天前
字符串改起来费劲。用枚举和对象都行吧
june4 楼主 小成 3 天前
@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'之类的,很容易让人误用。
返回顶部