如何通过变量设置JS对象属性名称

2020/10/20 09:01 · javascript ·  · 0评论

我需要动态设置JS对象属性名称。

for(i=1; i<3; i++) {
    var key  = i+'name';

    data = {
        key : 'name1',
    }
}

结果应为:

data = {
    1name: 'name1'
    2name: 'name1'
}

var jsonVariable = {};
for(var i=1; i < 3; i++) {
  jsonVariable[i + 'name'] = 'name' + i;        
}

您必须使用[]符号来动态设置键。

var jsonVariable = {};
for(i=1; i<3; i++) {        
 var jsonKey  = i+'name';
 jsonVariable[jsonKey] = 'name1';

}

现在在ES6中,您可以使用对象文字语法动态创建对象键,只需将变量包装在 []

var key  = i + 'name';
data = {
    [key] : 'name1',
}

使用ECMAScript 6,可以将变量属性名称与对象文字语法一起使用,如下所示:

var keyName = 'myKey';
var obj = {
              [keyName]: 1
          };
obj.myKey;//1

在以下较新的浏览器中可以使用此语法:

Edge 12+(不支持IE),FF34 +,Chrome 44 +,Opera 31 +,Safari 7.1+

https://kangax.github.io/compat-table/es6/

您可以通过使用诸如babel编译器为较旧的浏览器添加支持如果使用汇总webpack等模块捆绑器,则很容易转换整个项目

使用变量作为对象键

let key = 'myKey';

let data = {[key] : 'name1'; }

在此处查看如何对您的对象进行迭代

这是动态设置值的方法

var jsonVariable = {};
for (var i = 1; i < 3; i++) {
    var jsonKey = i + 'name';
    jsonVariable[jsonKey] = 'name' + i;
}

变量的来源无关紧要。我们要做的主要事情是...在方括号“ [..]”之间设置变量名称。

var optionName = 'nameA';
var JsonVar = {
[optionName] : 'some value'
}
jsonVariable = {}
for(i=1; i<3; i++) {        
   var jsonKey  = i+'name';
   jsonVariable[jsonKey] = 'name1'
}

这将类似于

    jsonVariable = {
    1name : 'name1'
    2name : 'name1'
}

遵循上述Sainath SR的评论,我可以通过定义对象,然后在对象外部定义另一个键/值,从Google Apps脚本(尚不支持ES6)中的变量设置js对象属性名称:

var salesperson = ...

var mailchimpInterests = { 
        "aGroupId": true,
    };

mailchimpInterests[salesperson] = true;
本文地址:http://javascript.askforanswer.com/ruhetongguobianliangshezhijsduixiangshuxingmingcheng.html
文章标签:
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!