Я просто объявляю интерфейс и использую переменную этого типа для доступа к enum. Синхронизация интерфейса и перечисления на самом деле проста, поскольку TypeScript жалуется, если что-то меняется в перечислении, например, так.
ошибка TS2345: Аргумент типа 'typeof EAbFlagEnum' не может быть назначен параметру типа 'IAbFlagEnum'. Свойство 'Move' отсутствует в типе 'typeof EAbFlagEnum'.
Преимущество этого метода в том, что для использования enum (interface) в различных ситуациях не требуется приведение типов, и таким образом поддерживается больше типов ситуаций, таких как switch / case.
// Declare a TypeScript enum using unique string
// (per hack mentioned by zjc0816)
enum EAbFlagEnum {
None = <any> "none",
Select = <any> "sel",
Move = <any> "mov",
Edit = <any> "edit",
Sort = <any> "sort",
Clone = <any> "clone"
}
// Create an interface that shadows the enum
// and asserts that members are a type of any
interface IAbFlagEnum {
None: any;
Select: any;
Move: any;
Edit: any;
Sort: any;
Clone: any;
}
// Export a variable of type interface that points to the enum
export var AbFlagEnum: IAbFlagEnum = EAbFlagEnum;
Использование переменной вместо перечисления дает желаемые результаты.
var strVal: string = AbFlagEnum.Edit;
switch (strVal) {
case AbFlagEnum.Edit:
break;
case AbFlagEnum.Move:
break;
case AbFlagEnum.Clone
}
Флаги были еще одной необходимостью для меня, поэтому я создал модуль NPM, который добавляет этот пример и включает тесты.
https://github.com/djabraham/ts-enum-tools