我有一种情况需要使用 key 拆分后端提供的 Json 对象。这是后端给的JSON的例子。
{
"answer": {
"E2": "Tony Stark",
"E3": "1",
"E4": "2",
"E6": "4",
"E8": "9120",
"E9": "01",
"F1": "Marvel",
"F2": "1",
"F4": "2",
"F6": "4",
"F8": "9120",
"F9": "01",
"G1": "02",
"G2": "02",
"G3": "02",
"H10": "Car"
}
}
我可以将答案分成 E、F、G 和 H 部分吗?预期结果为
{
"answer": [
{
"E2": "Tony Stark",
"E3": "1",
"E4": "2",
"E6": "4",
"E8": "9120",
"E9": "01",
"sectionName": "E"
},
{
"F1": "Marvel",
"F2": "1",
"F4": "2",
"F6": "4",
"F8": "9120",
"F9": "01",
"sectionName": "F"
},
{
"G1": "02",
"G2": "02",
"G3": "02",
"sectionName": "G"
},
{
"H10": "Car",
"sectionName": "H"
}
]
}
一定有天才可以解决我的问题。太感谢了。 任何建议表示赞赏。
最佳答案
遍历entries
对象并根据键的第一个字母对它们进行分组。如果组对象已经将字母作为键,则更新它。否则,将字母作为键添加到组对象。使用 Object.values()
获取输出中所需的 answer
数组
const input={answer:{E2:"Tony Stark",E3:"1",E4:"2",E6:"4",E8:"9120",E9:"01",F1:"Marvel",F2:"1",F4:"2",F6:"4",F8:"9120",F9:"01",G1:"02",G2:"02",G3:"02",H10:"Car"}};
const group = {};
for (const [k, v] of Object.entries(input.answer)) {
const sectionName = k.charAt(0);
if (group[sectionName])
group[sectionName][k] = v;
else
group[sectionName] = { sectionName, [k]: v };
}
const answer = Object.values(group)
console.log({ answer })
关于Javascript按键拆分JSON对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59083742/