【问题标题】:Create an object with dynamic property names [duplicate]创建具有动态属性名称的对象[重复]
【发布时间】:2013-07-23 20:16:21
【问题描述】:

我正在尝试这样做:

var KEYS = {} ;

KEYS.PHONE_TYPE = 'phone-type';
KEYS.AGENT_TYPE = 'agent-type';

var myAppConfig = {
    ...
    iconMap : { 
        KEYS.PHONE_TYPE : 'icon-phone', 
        KEYS.AGENT_TYPE : 'icon-headphones'
    };
    ...
};

但它失败了,并带有一条消息:Expected ':' and instead saw '.'.

如何使用间接(非文字)键名初始化对象?

说清楚,我想要的结果是:

{
    'phone-type' : 'icon-phone',
    'agent-type' : 'icon-headphones'
}

【问题讨论】:

标签: javascript


【解决方案1】:

如果你使用的是 ES6(或类似 Babel/browserify),你可以这样写:

iconMap : { 
    [KEYS.PHONE_TYPE] : 'icon-phone', 
    [KEYS.AGENT_TYPE] : 'icon-headphones'
};

【讨论】:

    【解决方案2】:

    您必须使用括号表示法分别添加这些属性:

    var myAppConfig = {
        ...
        iconMap : { }
        ...
    };
    
    myAppConfig.iconMap[ KEYS.PHONE_TYPE ] = 'icon-phone';
    myAppConfig.iconMap[ KEYS.AGENT_TYPE ] = 'icon-headphones';
    

    【讨论】:

    • 谢谢。我仍然感到惊讶的是,javascript 没有对具有动态键名的对象的初始化提供内置支持。 Python 可以为字典做到这一点,而且非常方便。我想这是因为引号在 javascript 属性中是可选的。
    • 我猜 JS 通过允许不带引号的属性名称放弃了这种可能性,Python 通过要求带引号的属性名称来避免这种情况。
    猜你喜欢
    • 2017-04-06
    • 1970-01-01
    • 1970-01-01
    • 2019-07-01
    • 1970-01-01
    相关资源
    最近更新 更多