我遇到了一个令人讨厌的JSON对象,我需要转换为具有可变深度的JS对象。
很快:(我使用jQuery)
var nastyJSON_string = "{"generics_utenteID":"1","generics_elencoID":"1","mainbar_ade_stepID_0":"1","mainbar_ade_stepID_1":"3","mainbar_ade_stepTitle_0":"blablabla", "mainbar_ade_stepTitle_1" : "quiquoqua"}";
var nastyJSON = JSON.parse(nastyJSON_string);
// nastyJSON if parsed correctly now is: {generics_utenteID:"1",generics_elencoID:"1" ...and so on}.
现在,我需要将nastyJSON转换为具有可变深度的JS对象。我的意思是:
var reusableJSObject = {
generics : {
utenteID : 1,
elencoID : 1
},
mainbar : {
ade : {
stepID : {
0 : 1,
1 : 3
},
stepTitle : {
0 : "blablabla",
1 : "quiquoqua"
}
}
}
}
我最好的方法是手动创建它,循环nastyJSON,切换套管键并创建在众所周知的深度末尾添加值的对象。
像这样:
jQuery.each(nastyJSON, function(key,value){
var keysp = key.split('_');
switch(keysp[0])
{
//# generics
case 'generics':
if(!reusableJSObject.hasOwnProperty(keysp[0])) { reusableJSObject[keysp[0]] = new Object(); };
switch(keysp[1])
{
//# utenteID
case 'utenteID':
if(!reusableJSObject[keysp[0]].hasOwnProperty(keysp[1])) { reusableJSObject[keysp[0]][keysp[1]]; };
reusableJSObject[keysp[0]][keysp[1]] = Number(value);
break;
//# elencoID
case 'elencoID':
if(!reusableJSObject[keysp[0]].hasOwnProperty(keysp[1])) { reusableJSObject[keysp[0]][keysp[1]]; };
reusableJSObject[keysp[0]][keysp[1]] = Number(value);
break;
}
break;
//# mainbar
case 'mainbar':
if(!reusableJSObject.hasOwnProperty(keysp[0])) { reusableJSObject[keysp[0]] = new Object(); };
break;
//... and So On!
}
});
但是,如果我一开始不知道nastyJSON结构,我只知道nastyJSON有关键我必须拆分并嵌套直到拆分结束?
提前致谢。
答案 0 :(得分:3)
你不需要jQuery,vanilla JS会做(here是小提琴):
var json = '{"generics_utenteID":"1","generics_elencoID":"1","mainbar_ade_stepID_0":"1","mainbar_ade_stepID_1":"3","mainbar_ade_stepTitle_0":"blablabla", "mainbar_ade_stepTitle_1" : "quiquoqua"}';
var obj = JSON.parse(json);
function parse(object) {
var result = {};
var temp = {};
var keys;
for (var property in object) {
keys = property.split('_');
temp = result;
for (var i = 0; i < keys.length - 1; i++) {
if (typeof temp[keys[i]] == 'undefined') {
temp[keys[i]] = {};
}
temp = temp[keys[i]];
};
temp[keys[i]] = object[property];
}
return result;
}
console.log(JSON.stringify(parse(obj)));
输出:
{
"generics":{
"utenteID":"1",
"elencoID":"1"
},
"mainbar":{
"ade":{
"stepID":{
"0":"1",
"1":"3"
},
"stepTitle":{
"0":"blablabla",
"1":"quiquoqua"
}
}
}
}