Javascript关联数组声明中的动态键一行

时间:2013-07-24 17:06:42

标签: javascript

我希望以下三个关联数组是相同的:

arr1 = { "dynamic":"foo", "bar":"baz" };

key = "dynamic";    
arr2 = { key:"foo", "bar":"baz" };

arr3 = {};
arr3[key] = "foo";
arr3["bar"] = "baz";

在上面的示例中,arr1arr3相同,但arr2不同。

是否可以在javascript关联数组的声明中使用动态键?

5 个答案:

答案 0 :(得分:8)

现在可以在任何支持ES6文字缩写的浏览器/平台中使用javascript对象声明中的动态键:

key = "dynamic";    
arr2 = {
    [key]: "foo",  // "dynamic": "foo"
    "bar": "baz"
};

答案 1 :(得分:7)

只有[]语法适用于动态密钥。你不能在文字中使用它们。所以你的答案是否定的,这是不可能的。

但您可以使用文字来创建所有静态密钥,然后使用[]语法添加动态密钥。这通常比使用所有元素的.[]表示法更漂亮。

答案 2 :(得分:2)

我找到了解决方案。

执行以下操作:

var field='name';

var ourVar={};

ourVar[field] = 'Somethig';

来源:Javascript: variable as array key

答案 3 :(得分:0)

由于你要求一个班轮,试试这个:

var key = 'dynamic', obj = (function(o) { o[key]='foo'; return o;})({bar: 'baz'});

这会使obj等于{bar: "baz", dynamic: "foo"}

答案 4 :(得分:0)

var originalObj = {};//some data here


function addKeyValuePair(originalObj,key,value){
    originalObj = {...originalObj,[key]:value}
};