繁体   English   中英

在打字稿中映射枚举

[英]Mapping enum in typescript

在打字稿中映射枚举的正确方法是什么?

例如,我正在玩一个在线打字稿代码编辑器,这很好用:

class Message
{
    name: string;
    min: number;
    max: number;
    messageType: MessageType;
}

enum MessageType
{
    none,
    email,
    sms

}

var jsonObj = {
    "name": "some name",
    "min": 0,
    "max": 10,
    "messageType": MessageType.email

}

var messageInstance: Message = <Message>jsonObj;

console.log(messageInstance);

但是,在我的IDE中,如果我在json文件中使用它, MessageType.email显示“value expected”错误。

如果我尝试:

"messageType": "MessageType.email"

在在线代码编辑器中,然后生成错误。

我刚刚开始,无法找到有关如何完成此操作的明确说明。

编辑:

我刚刚意识到枚举是基于数字所以"messageType": 2或任何相应的数字将是正确的方法去。

有没有办法让json文件中的枚举可读(比如像MessageType.email这样的值),因为单独查看时json文件没有枚举定义所以可能会让人感到困惑,所以我宁愿这样做方式如果可能..

对于TypeScript 2.4+:

您可以使用字符串枚举而不是数字枚举:

enum MessageType
{
    none = "none",
    email = "email",
    sms = "sms"
}

对于旧版本的TypeScript:

您可以使用enum的索引器将enum值转换为string

const messageTypeAsString = MessageType[MessageType.email];

走另一条路也是有效的:

const messageType: MessageType = MessageType[messageTypeAsString];

据我所知,在序列化/反序列化JSON时无法自动执行此转换。

另一种选择是完全跳过enum并使用静态string s:

class MessageType {
    static readonly none = 'none';
    static readonly email = 'email';
    static readonly sms = 'sms';
}
type MessageTypeValue = 'none' | 'email' | 'sms'; 

const messageType: MessageTypeValue = MessageType.none;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM