Typescript Enum Object.values() 返回值

Leh*_*hks 14 enums typescript

为什么Object.values()Object.keys()总是给这两个键和值?

考虑以下代码:

enum Enum {
    FOO,
    BAR
}

console.log(Object.values(Enum));
console.log(Object.keys(Enum));
Run Code Online (Sandbox Code Playgroud)

其输出将是:

[ 'FOO', 'BAR', 0, 1 ]
[ '0', '1', 'FOO', 'BAR' ]
Run Code Online (Sandbox Code Playgroud)

为什么这样做,我如何只获取键和值?

p.s*_*w.g 17

这就是enumTypeScript 转换类型的方式。

enum Enum {
    FOO,
    BAR
}
Run Code Online (Sandbox Code Playgroud)

会变成

"use strict";
var Enum;
(function (Enum) {
    Enum[Enum["FOO"] = 0] = "FOO";
    Enum[Enum["BAR"] = 1] = "BAR";
})(Enum || (Enum = {}));
Run Code Online (Sandbox Code Playgroud)

请注意,提供了数字键和字符串键以方便与这两种类型之间的映射,使您能够执行以下操作:

const value = Enum.FOO;  // inferred type Enum.FOO
const key = Enum[value]; // inferred type string
Run Code Online (Sandbox Code Playgroud)

如果你想得到一个只有数字或字符串键的数组,你可以这样做:

const numericKeys = Object.keys(Enum).map(x => parseInt(x)).filter(x => !isNaN(x));
const stringKeys = Object.keys(Enum).filter(x => isNaN(parseInt(x)));
Run Code Online (Sandbox Code Playgroud)

或者对于数字或字符串值(需要es2017在您的库中tsconfig):

const numericValues = Object.values(Enum).filter(x => typeof x === "number");
const stringValues = Object.values(Enum).filter(x => typeof x === "string");
Run Code Online (Sandbox Code Playgroud)

  • `const value = Object.values(Enum).filter(v => typeof v === 'number');` (5认同)