首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >lit/lit-element中的枚举属性

lit/lit-element中的枚举属性
EN

Stack Overflow用户
提问于 2021-05-11 00:34:22
回答 2查看 165关注 0票数 2

我们正在尝试构建一个具有属性variant的组件,该属性仅应设置为"primary""secondary" (枚举)。目前,我们只是将属性声明为字符串,但我们想知道是否有更好的方法来处理枚举?例如,我们是否应该以某种方式验证当前值是枚举的一部分?如果不是,我们应该抛出一个错误吗?

EN

回答 2

Stack Overflow用户

发布于 2021-05-11 01:55:27

我在Slack上问了这个问题,得到的答案倾向于将属性声明为字符串,并使用hasChanged()在属性值无效时在控制台中显示警告。标准的HTML元素接受任何字符串作为属性值,并且不会抛出异常,因此web组件可能也应该以同样的方式工作。

对我来说,这一切听起来都是合理的。

票数 1
EN

Stack Overflow用户

发布于 2021-05-20 05:14:27

如果你使用的是TypeScript,我建议你只使用字符串。您可以使用export type MyEnum = 'primary' | 'secondary'来声明它,然后使用@property() fooBar: MyEnum来获得构建时检查。您也可以使用@ts-check在纯JS中使用@type MyEnum来完成此操作。

如果枚举用于组件选项或映射到将再次验证的服务器端枚举,则此方法效果很好。

但是,如果您想要验证用户输入到枚举中或多次遍历它们,这就不太好了。当JS运行时,它没有该类型的可见性。您需要一个对象字典,类似于:

代码语言:javascript
复制
const MyEnum = Object.freeze({
    primary: 'primary',
    secondary: 'secondary'
});

// Enforce type in TS
const value: keyof MyEnum;

// Validate
const validated = MyEnum[input.toLower()];

// Loop
for(const enumVal of Object.keys(MyEnum)) ...

// Or Convert to a different value type
const MyEnum = Object.freeze({
    primary: 1,
    secondary: 2
});

这些都有些特殊。同样,如果你使用的是TypeScript,它有一个enum关键字,它编译成类似这样的东西,我会使用它,而不是使用你自己的。字符串是更好的选择,除非您需要验证、循环或转换值。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67474303

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档