打字稿:如何循环显示枚举值以便在单选按钮中显示?

Ant*_*ère 134 javascript arrays enums element typescript

在Typescript中循环枚举枚举的正确方法是什么?(目前使用的是typescrip 1.8.1)

我有以下枚举:

export enum MotifIntervention {
    Intrusion,
    Identification,
    AbsenceTest,
    Autre
}

export class InterventionDetails implements  OnInit
{
constructor( private interService: InterventionService )
{
    let i:number = 0;
    for (let motif in MotifIntervention) {
        console.log( motif );
    }
}
Run Code Online (Sandbox Code Playgroud)

显示的结果是一个列表

0
1
2
3
Intrusion,
Identification,
AbsenceTest,
Autre
Run Code Online (Sandbox Code Playgroud)

我确实只想在循环中进行4次迭代,因为枚举中只有4个元素,我不希望0 1 2和3看起来像是枚举的索引号.

Nit*_*mer 249

两种选择:

for (let item in MotifIntervention) {
    if (isNaN(Number(item))) {
        console.log(item);
    }
}
Run Code Online (Sandbox Code Playgroud)

要么

Object.keys(MotifIntervention).filter(key => !isNaN(Number(MotifIntervention[key])));
Run Code Online (Sandbox Code Playgroud)

(游乐场代码)


编辑

字符串枚举看起来与常规枚举不同,例如:

enum MyEnum {
    A = "a",
    B = "b",
    C = "c"
}
Run Code Online (Sandbox Code Playgroud)

编译成:

var MyEnum;
(function (MyEnum) {
    MyEnum["A"] = "a";
    MyEnum["B"] = "b";
    MyEnum["C"] = "c";
})(MyEnum || (MyEnum = {}));
Run Code Online (Sandbox Code Playgroud)

这只是给你这个对象:

{
    A: "a",
    B: "b",
    C: "c"
}
Run Code Online (Sandbox Code Playgroud)

你可以得到所有的键(["A", "B", "C"]):

Object.keys(MyEnum);
Run Code Online (Sandbox Code Playgroud)

而值(["a", "b", "c"]):

Object.keys(MyEnum).map(key => MyEnum[key])
Run Code Online (Sandbox Code Playgroud)

或者使用Object.values():

Object.values(MyEnum)
Run Code Online (Sandbox Code Playgroud)

  • 谢谢你这种方法.对于`Object.keys`方法,你需要使用`Object.keys(MotifIntervention).filter(key => isNaN(Number(key)))`. (7认同)
  • 它不起作用,因为 0 1 2 3 是字符串。 (4认同)
  • 这就是检查`isNaN(Number(...))`的原因.它在我分享的操场上工作 (4认同)
  • @NitzanTomer-在运行时听起来像是一个很好的解决方法,但是我在谈论编译时。当您尝试调用`doThing(item)`并且`doThing`类型为((arg:MotifIntervention)=> void`时,会出现编译时错误**“类型'string'的参数不可分配给“ MotifIntervention”类型的参数。” ** (3认同)
  • 如果您希望遍历枚举类型的值,则此方法无效。因此,如果`typeof doThing`函数为`(arg:MotifIntervention)=> void`,则for for(让MotifIntervention中的项目){doThing(item)}`将失败。这是因为for..in循环会将项目视为字符串类型,而不是MotifIntervention类型。 (2认同)