¿Cómo puedo recorrer los valores de enumeración para mostrarlos en los botones de opción? [duplicar]

Resuelto Anthony Brenelière asked hace 8 años • 1 respuestas

¿Cuál es la forma correcta de recorrer los literales de una enumeración en TypeScript?

(Actualmente estoy usando TypeScript 1.8.1).

Tengo la siguiente enumeración:

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);
        }
    }

El resultado mostrado es una lista.

0
1
2
3
Intrusion,
Identification,
AbsenceTest,
Autre

Solo quiero cuatro iteraciones en el bucle ya que solo hay cuatro elementos en la enumeración. No quiero tener 0 1 2 y 3 que parezcan ser números índice de la enumeración.

Anthony Brenelière avatar Sep 07 '16 21:09 Anthony Brenelière
Aceptado

Dos opciones:

for (let item in MotifIntervention) {
    if (isNaN(Number(item))) {
        console.log(item);
    }
}

O

Object.keys(MotifIntervention).filter(key => !isNaN(Number(MotifIntervention[key])));

( código en el patio de recreo )


Editar

Las enumeraciones de cadenas se ven diferentes a las normales, por ejemplo:

enum MyEnum {
    A = "a",
    B = "b",
    C = "c"
}

Se compila en:

var MyEnum;
(function (MyEnum) {
    MyEnum["A"] = "a";
    MyEnum["B"] = "b";
    MyEnum["C"] = "c";
})(MyEnum || (MyEnum = {}));

Lo que solo te da este objeto:

{
    A: "a",
    B: "b",
    C: "c"
}

Puede obtener todas las claves ( ["A", "B", "C"]) de esta manera:

Object.keys(MyEnum);

Y los valores ( ["a", "b", "c"]):

Object.keys(MyEnum).map(key => MyEnum[key])

O usando Object.values() :

Object.values(MyEnum)
Nitzan Tomer avatar Sep 07 '2016 14:09 Nitzan Tomer