我的数据目前以这种格式存储,存储在JSON文件中:
{
"name": {
"0": ______,
"1": ______,
"2": ______
},
"xcoord": {
"0": ______,
"1": ______,
"2": ______
},
"ycoord": {
"0": ______,
"1": ______,
"2": ______
}
}
我需要将它转换为这种格式,作为对象数组:
[
{
"id": 0,
"name": _____,
"xcoord": _____,
"ycoord": _____
},
{
"id": 1,
"name": _____,
"xcoord": _____,
"ycoord": _____
},
{
"id": 2,
"name": _____,
"xcoord": _____,
"ycoord": _____
}
]
如您所见,我还需要使用第一种数据格式的数字键,并将其作为第二种数据格式的“id”值。 (由于数组中对象的位置和id号匹配,也许这是创建“id”键的另一种方式?)然后我将我的第二种数据格式存储到一个局部变量中以用于我的JS代码
关于我如何做到这一点的任何想法?我不太擅长重组这类数据。
答案 0 :(得分:2)
例如,可以使用两个重叠的.forEach()
:
var obj = {
"name": {
0: 'name0',
1: 'name1',
2: 'name2'
},
"xcoord": {
0: 'xcoord0',
1: 'xcoord1',
2: 'xcoord2'
},
"ycoord": {
0: 'ycoord0',
1: 'ycoord1',
2: 'ycoord2'
}
};
var res = [];
Object.keys(obj).forEach(k => {
Object.keys(obj[k]).forEach(v => {
(res[v] = (res[v] || { id: v }))[k] = obj[k][v];
});
});
console.log(res);
注意强>:
这一行...
(res[v] = (res[v] || { id: v }))[k] = obj[k][v]
...是一个简短的方法:
if(!res[v]) {
// if this record doesn't exist yet,
// create it with its implied 'id' property
res[v] = { id: v };
}
// add property 'k' to this record
res[v][k] = obj[k][v];