Dies ist die JavaScript-Ausgabe dieser Aufzählung:
var MyEnum;
(function (MyEnum) {
MyEnum[MyEnum["First"] = 0] = "First";
MyEnum[MyEnum["Second"] = 1] = "Second";
MyEnum[MyEnum["Third"] = 2] = "Third";
})(MyEnum || (MyEnum = {}));
Welches ist ein Objekt wie dieses:
{
"0": "First",
"1": "Second",
"2": "Third",
"First": 0,
"Second": 1,
"Third": 2
}
Enum-Mitglieder mit String-Werten
TypeScript 2.4 hat die Möglichkeit hinzugefügt, dass Enums möglicherweise Werte für String-Enum-Mitglieder haben. Es ist also möglich, eine Aufzählung zu erhalten, die wie folgt aussieht:
enum MyEnum {
First = "First",
Second = 2,
Other = "Second"
}
// compiles to
var MyEnum;
(function (MyEnum) {
MyEnum["First"] = "First";
MyEnum[MyEnum["Second"] = 2] = "Second";
MyEnum["Other"] = "Second";
})(MyEnum || (MyEnum = {}));
Mitgliedsnamen abrufen
Wir können uns das Beispiel direkt oben ansehen, um herauszufinden, wie man die Enum-Mitglieder erhält:
{
"2": "Second",
"First": "First",
"Second": 2,
"Other": "Second"
}
Folgendes habe ich mir ausgedacht:
const e = MyEnum as any;
const names = Object.keys(e).filter(k =>
typeof e[k] === "number"
|| e[k] === k
|| e[e[k]]?.toString() !== k
);
Mitgliedswerte
Sobald wir die Namen haben, können wir sie durchlaufen, um den entsprechenden Wert zu erhalten, indem wir Folgendes tun:
const values = names.map(k => MyEnum[k]);
Erweiterungsklasse
Ich denke, der beste Weg, dies zu tun, besteht darin, eigene Funktionen zu erstellen (z. B. EnumEx.getNames(MyEnum)
). Sie können einer Aufzählung keine Funktion hinzufügen.
class EnumEx {
private constructor() {
}
static getNamesAndValues(e: any) {
return EnumEx.getNames(e).map(n => ({ name: n, value: e[n] as string | number }));
}
static getNames(e: any) {
return Object.keys(e).filter(k =>
typeof e[k] === "number"
|| e[k] === k
|| e[e[k]]?.toString() !== k
);
}
static getValues(e: any) {
return EnumEx.getNames(e).map(n => e[n] as string | number);
}
}