从枚举(角度)填充数组

时间:2019-06-11 13:53:05

标签: javascript angular typescript

我有enum,它来自后端

这里是枚举

    export enum InquiryStatus {
    _0 = 0, 
    _1 = 1, 
    _2 = 2, 
}

我创建枚举,像这样在下拉菜单中使用

  export enum InquiryStatuses {
    Pending = InquiryStatus._0,
    Quoted = InquiryStatus._1,
    Lost = InquiryStatus._2,
}

然后像这样填充数组

filter: SelectItem[] = [];
     ngOnInit(): void {
        this.filter = [
            { label: 'Pending', value: InquiryStatuses.Pending },
            { label: 'Quoted', value: InquiryStatuses.Quoted },
            { label: 'Lost', value: InquiryStatuses.Lost },
        ];
    }

我需要在函数中进行填充。即,将数组的名称和名称作为参数,并将填充的数据返回到数组。 我该如何正确执行此操作?

2 个答案:

答案 0 :(得分:2)

执行此操作的常用方法可能是这样的:

this.filter = Object.keys(InquiryStatuses)
                  .filter(k => typeof InquiryStatuses[k] === 'number')
                  .map(label => ({ label, value: InquiryStatuses[label] })))

由于Typescript在转换为对象时会将枚举中的属性“加倍”,因此我们必须首先对其进行过滤。

答案 1 :(得分:1)

由于yurzui写了一个很好的答案,所以我只添加我做类似事情的方式。

export class EnumHelper {

    /** Returns array of objects based on enum values.
     *  Every object has text and value. 
     * Formats enum names if they are in pascal case.*/
    public static getTextAndValue(type: any, pascalCase: boolean = false): object[] {
        const result: Array<object> = [];
        for (var value in type) {
            if (Number.isInteger(type[value])) {
                result.push({ value: type[value], text: pascalCase ? value.replace(/([A-Z])/g, ' $1').trim() : value });
            }
        }
        return result;
    }
}