我已经获得了这些测试输入,这些输入需要被解析为一个JSON对象,这些JSON对象由他们的Key按下划线组合。
var testInput1 = '{"Data_Structure_Test1": "Test1 Data"}';
var testInput2 = '{"Data_Structure_Test2": "Test2 Data"}';
var testInput3 = '{"Data_Structure_Test3": "Test3 Data"}';
var testInput4 = '{"Data_AnotherStructure": "AnotherStructure Data"}';
var testInput5 = '{"Data_JustAnother": "JustAnother Data"}';
var testInput6 = '{"NewData_NewTest": "NewTest Data"}';
所以上面的testInputs
应该吐出来:
{
"Data": {
"Structure": {
"Test1": "Test1 Data",
"Test2": "Test2 Data",
"Test3": "Test3 Data"
},
"AnotherStructure": "AnotherStructure Data",
"JustAnother": "JustAnother Data"
},
"NewData": {
"NewTest": "NewTest Data"
}
}
我似乎无法将JSON对象收集到正确的容器中。
Here is a JSFiddle that I have been using to test with
这是我正在调用解析字符串
的函数function parse_input(aInput) {
let jObj = JSON.parse(aInput);
for (let key in jObj) {
let objKeys = key.split("_");
for (i = 0; i < objKeys.length; i++) {
if (data.hasOwnProperty(objKeys[i])) {
data[key] = jObj[key];
} else {
data[objKeys[i]] = jObj[key];
}
}
我是如何传递输入的:
var data = {};
parse_input(testInput1);
parse_input(testInput2);
parse_input(testInput3);
parse_input(testInput4);
parse_input(testInput5);
parse_input(testInput6);
var result = JSON.stringify(data, undefined, '\t');
谁能看到我做错了什么?
我确实可以访问jQuery
框架,如果这样做会更容易。
答案 0 :(得分:2)
function parse_input(json){
const obj = JSON.parse(json);
for(const key in obj){
const keys = key.split("_");
keys.slice(0,-1).reduce(function(obj, key){
return obj[key] || (obj[key] = {});
}, data)[keys.pop()] = obj[key];
}
}
您可能希望使用 reduce 深入数据对象。