Javascript 将javascript枚举键字符串转换为值

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/39551568/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-23 22:40:45  来源:igfitidea点击:

convert javascript enum key string to value

javascript

提问by chuckp

In JavaScript code, I have the following enum defined:

在 JavaScript 代码中,我定义了以下枚举:

MyMessageIds = {
    UndefinedId : 0,
    FilenameId : 1,
    BuildFileId : 2,
    MovementArgsId : 3,
    MoveId : 4,
    ExecuteCommandId : 5
}

In a JavaScript function, I would like to be able to supply the string representation of an enum key (i.e. "MoveId") and return its integer value of 4. So how could I do this?

在 JavaScript 函数中,我希望能够提供枚举键的字符串表示(即“MoveId”)并返回其整数值 4。那么我该怎么做呢?

回答by baao

Just use bracket notation:

只需使用括号表示法:

var MyMessageIds = {
    UndefinedId : 0,
    FilenameId : 1,
    BuildFileId : 2,
    MovementArgsId : 3,
    MoveId : 4,
    ExecuteCommandId : 5
};

function getValue(key) {
    return MyMessageIds[key];
}

回答by Mr. Polywhirl

You could create some utility methods which take an object (enum) that figures out how to get the keys/values.

您可以创建一些实用方法,这些方法采用一个对象(枚举)来确定如何获取键/值。

var MyMessageIds = {
    UndefinedId : 0,
    FilenameId : 1,
    BuildFileId : 2,
    MovementArgsId : 3,
    MoveId : 4,
    ExecuteCommandId : 5
}

function getEnumKeys(enumType) {
  return Object.keys(MyMessageIds);
}

function getEnumValues(enumType) {
  return getEnumKeys(enumType).map(function(key) {
    return enumType[key];
  });
}

function getEnumValue(enumType, key) {
  return enumType[getEnumKeys(enumType).filter(function(k) {
    return key === k;
  }).pop() || ''];
}

document.body.innerHTML = '<pre>' + JSON.stringify({
  'Enum Keys' : getEnumKeys(MyMessageIds),
  'Enum Vals' : getEnumValues(MyMessageIds),
  'Example' : {
    'MoveId' : getEnumValue(MyMessageIds, 'MoveId')
  }
}, null, 4) + '</pre>';

You could also create your own class object to represent an enum which has reusable methods.

您还可以创建自己的类对象来表示具有可重用方法的枚举。

function Enum() {
  this.self = arguments[0];
}
Enum.prototype = {
  keys : function() {
    return Object.keys(this.self);
  },
  values : function() {
    var me = this;
    return this.keys(this.self).map(function(key) {
      return me.self[key];
    });
  },
  getValueByName : function(key) {
    return this.self[this.keys(this.self).filter(function(k) {
      return key === k;
    }).pop() || ''];
  },
  getNameByValue : function(value) {
    var me = this;
    return this.keys(this.self).filter(function(k) {
      return me.self[k] === value;
    }).pop() || null;
  }
};

var MyMessageIds = new Enum({
    UndefinedId : 0,
    FilenameId : 1,
    BuildFileId : 2,
    MovementArgsId : 3,
    MoveId : 4,
    ExecuteCommandId : 5
});

document.body.innerHTML = '<pre>' + JSON.stringify({
  'Enum Keys' : MyMessageIds.keys(),
  'Enum Vals' : MyMessageIds.values(),
  'Example' : {
    'MoveId' : MyMessageIds.getValueByName('MoveId'),
    'Val(3)' : MyMessageIds.getNameByValue(3)
  }
}, null, 4) + '</pre>';