Po prostu deklaruję interfejs i używam zmiennej tego typu, aby uzyskać dostęp do wyliczenia. Utrzymanie synchronizacji interfejsu i wyliczania jest w rzeczywistości łatwe, ponieważ TypeScript narzeka, jeśli coś zmienia się w wyliczeniu, tak jak to.
błąd TS2345: Argumentu typu „typeof EAbFlagEnum” nie można przypisać do parametru typu „IAbFlagEnum”. Brak właściwości „Przenieś” w typie „typeof EAbFlagEnum”.
Zaletą tej metody jest to, że rzutowanie typu nie jest wymagane w celu użycia wyliczenia (interfejsu) w różnych sytuacjach, a zatem obsługiwanych jest więcej typów sytuacji, takich jak przełącznik / obudowa.
// 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;
Użycie zmiennej zamiast wyliczenia daje pożądane wyniki.
var strVal: string = AbFlagEnum.Edit;
switch (strVal) {
case AbFlagEnum.Edit:
break;
case AbFlagEnum.Move:
break;
case AbFlagEnum.Clone
}
Flagi były dla mnie kolejną koniecznością, dlatego stworzyłem moduł NPM, który dodaje się do tego przykładu i zawiera testy.
https://github.com/djabraham/ts-enum-tools