Typescript枚举,接口和映射

时间:2018-04-27 15:27:13

标签: typescript

在TypeScript中,在数组或类似的数据结构中,如何将字符串映射到id,同时确保只允许一定范围的id?

这是我想要做的。这很好用。但是,我想知道是否有更简洁的方法来实现这一目标?

enum ETypeId {
    alpha  = "a",
    beta   = "b",
    gamma  = "g"
}

interface IType {
    id:     ETypeId,
    title:  string,
}

myTypes: IType[] = [
    { id: ETypeId.alpha, title: "Alpha" },
    { id: ETypeId.beta,  title: "Beta"  },
    { id: ETypeId.gamma, title: "Gamma" }
];

按原样,我必须执行以下操作才能从id转到title

function getTypeForTypeId( typeId: ETypeId ): IType {
    return myTypes.find( type => type.id == typeId );
}

我可以使用不同的数据结构,使上面的代码更简洁,或者这已经很好了吗?

说明:

  • "a"是存储在我的数据库中的内容
  • ETypeId.alpha是我在代码中访问它的方式
  • "Alpha"是向用户显示的内容。

2 个答案:

答案 0 :(得分:4)

同意Sergi Dote Teixidor's回答Map是此类问题的最佳选择。但是,基于所描述的问题,我认为它可以简化为Map<ETypeId, string>

enum ETypeId {
    alpha  = "a",
    beta   = "b"
}

const types: Map<ETypeId, string> = new Map( [
   [ ETypeId.alpha, "Alpha" ],
   [ ETypeId.beta, "Beta" ],
]);

以防您想要初始化一次结构并使TypeScript保护您不要更改地图中的值:

enum ETypeId {
    alpha  = "a",
    beta   = "b"
}

interface ReadonlyMap<TKey, TValue> {
    get(key: TKey):TValue;
}

const types: ReadonlyMap<ETypeId, string> = new Map( [
   [ ETypeId.alpha, "Alpha" ],
   [ ETypeId.beta, "Beta" ],
]);

// Static analyzer error if you try to change the value:
types.set(ETypeId.alpha, "NewValue");

答案 1 :(得分:2)

你可以使用地图:

  1. 您可以直接检索任何元素
  2. 如果需要,可以循环所有元素
  3. 示例:

    int *