71

我有一个充满 ips 的 json 对象

var ips = {}

然后我像这样将ip对象添加到这个对象

ips[ipID] = {}

然后我需要为每个 ip 添加动态/变量名称值对,所以我使用这样的代码

var name; var value; var temp = {};
tmp[name] = value

我的问题是,如何将这些名称值对/ tmp 添加到我的 ipID 对象中,这样我的结果就会像

ipID = { name : value, anotherName : anotherValue }
4

8 回答 8

205

那不是 JSON。它只是 Javascript 对象,与 JSON 毫无关系。

您可以使用方括号动态设置属性。例子:

var obj = {};
obj['name'] = value;
obj['anotherName'] = anotherValue;

这与使用这样的对象字面量创建对象完全相同:

var obj = { name : value, anotherName : anotherValue };

如果您已经将对象添加到ips集合中,则使用一对括号来访问集合中的对象,并使用另一对括号来访问对象中的属性:

ips[ipId] = {};
ips[ipId]['name'] = value;
ips[ipId]['anotherName'] = anotherValue;

请注意与上面的代码相似,但您只是使用ips[ipId]而不是obj.

您还可以从集合中获取对对象的引用,并在对象保留在集合中时使用它来访问对象:

ips[ipId] = {};
var obj = ips[ipId];
obj['name'] = value;
obj['anotherName'] = anotherValue;

您可以使用字符串变量来指定属性的名称:

var name = 'name';
obj[name] = value;
name = 'anotherName';
obj[name] = anotherValue;

它是标识属性的变量(字符串)的值,因此当您obj[name]在上面的代码中使用这两个属性时,在您访问它时变量中的字符串决定了将访问的属性。

于 2010-11-01T17:50:12.153 回答
30

ECMAScript 6 有一个更好的方法。

您可以在对象属性定义中使用计算属性名称,例如:

var name1 = 'John'; 
var value1 = '42'; 
var name2 = 'Sarah'; 
var value2 = '35';

var ipID = { 
             [name1] : value1, 
             [name2] : value2 
           }

这等效于以下内容,其中您有属性名称的变量。

var ipID = { 
             John: '42', 
             Sarah: '35' 
           }
于 2017-06-20T21:31:38.953 回答
8

使用 javascript 对象时,您也可以只使用“点符号”来添加一个项目,(JSLint 更喜欢

var myArray = { name : "john" };
//will initiate a key-value array with one item "name" and the value "john"
myArray.lastName = "smith";
//will add a key named lastName with the value "smith"
//Object {name: "john", lastName: "smith"}

这是在 Chrome 控制台中测试的屏幕截图

截屏

于 2015-03-11T17:09:14.977 回答
5

我假设“ips”中的每个条目都可以有多个名称值对 - 所以它是嵌套的。您可以这样实现此数据结构:

var ips = {}

function addIpId(ipID, name, value) {
    if (!ips[ipID]) ip[ipID] = {};
    var entries = ip[ipID];
    // you could add a check to ensure the name-value par's not already defined here
    var entries[name] = value;
}
于 2010-11-01T17:49:46.493 回答
3

在 Javascript 中。

    var myObject = { "name" : "john" };
    // { "name" : "john" };
    myObject.gender = "male";
    // { "name" : "john", "gender":"male"};
于 2016-06-17T06:52:16.903 回答
3

如果我对您的初始 JSON 的理解是正确的,那么这些解决方案中的任何一个都可以帮助您遍历所有 ip id 并为每个 id 分配一个新对象。

// initial JSON
var ips = {ipId1: {}, ipId2: {}};

// Solution1
Object.keys(ips).forEach(function(key) {
  ips[key] = {name: 'value', anotherName: 'another value'};
});

// Solution 2
Object.keys(ips).forEach(function(key) {
  Object.assign(ips[key],{name: 'value', anotherName: 'another value'});
});

确认:

console.log(JSON.stringify(ips, null, 2));

上面的语句吐槽:

{
  "ipId1": {
    "name":"value",
    "anotherName":"another value"
  },
  "ipId2": {
    "name":"value",
    "anotherName":"another value"
  }
}
于 2018-04-25T13:37:12.930 回答
1

从其他答案的建议来看,我相信这可能会有所帮助:

var object = ips[ipId];
var name = "Joe";
var anothername = "Fred";
var value = "Thingy";
var anothervalue = "Fingy";
object[name] = value;
object[anothername] = anothervalue;

然而,这没有经过测试,只是基于不断重复的假设:

object["string"] = value;
//object = {string: value}
于 2015-05-29T12:53:32.287 回答
0

您可以使用Lodash _.assign函数来实现这一点。

var ipID = {};
_.assign(ipID, {'name': "value"}, {'anotherName': "anotherValue"});
console.log(ipID);
<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.10/lodash.min.js"></script>

于 2018-09-04T07:50:47.490 回答