【发布时间】:2014-06-12 20:29:46
【问题描述】:
我正在处理这个 JSON,试图获取所有的键和值。我的问题是,在某些情况下,内部对象中有更多的键和值,
这只能在 JavaScript 中递归完成吗?我错过了什么?
{
"@xmlns:v6": "urn://oracle.bi.webservices/v6",
"v6:pageID": "?",
"v6:reportID": "?",
"v6:report": {
"v6:reportPath": "?",
"v6:reportXml": "?"
},
"v6:reportViewName": "?",
"v6:reportParams": {
"comment": [
"Zero or more repetitions: ",
"Zero or more repetitions: ",
"Zero or more repetitions: ",
"Zero or more repetitions: ",
"Optional: "
],
"v6:filterExpressions": "?",
"v6:variables": {
"v6:name": "?",
"v6:value": "?"
},
"v6:nameValues": {
"v6:name": "?",
"v6:value": "?"
},
"v6:templateInfos": {
"v6:templateForEach": "?",
"v6:templateIterator": "?",
"comment": "Zero or more repetitions: ",
"v6:instance": {
"v6:instanceName": "?",
"comment": "Zero or more repetitions: ",
"v6:nameValues": {
"v6:name": "?",
"v6:value": "?"
}
}
},
"v6:viewName": "?"
},
"v6:options": {
"v6:enableDelayLoading": "?",
"v6:linkMode": "?"
},
"v6:sessionID": "?"
}
这是我正在尝试使用的代码:
function parse(data,child,parent){
var nextRept = false;
if(child){
for(var i = 0; i < tmp.parents.length ; i++){
if(tmp.parents[i].name == parent){
if(!tmp.parents[i].children)
tmp.parents[i].children = [];
var keys = Object.keys(data);
for (var k = 0; k < keys.length; k++) {
var val = data[keys[k]];
if(typeof val === 'object')
{
tmp.parents.push({name: keys[k].replace("v6:","")} ); //adding the parent
parse(val,true,keys[k].replace("v6:","")); // adding children recursively
}
if(val == '?')
{ // handle valid param
var attr = false;
if(keys[k].indexOf('@') == 0){
attr = true;
keys[k] = keys[k].replace("@","");
}
tmp.parents[i].children.push({name: keys[k].replace("v6:","") , value : val , isAttr : attr , isRepet : nextRept});
isRepet = false;
}
}
return;
}
}
return;
}
var keys = Object.keys(data);
for (var i = 0; i < keys.length; i++) {
var val = data[keys[i]];
if(typeof val === 'object')
{
tmp.parents.push({name: keys[i].replace("v6:","")} ); //adding the parent
parse(val,true,keys[i].replace("v6:","")); // adding children recursively
}
else{
if(val.indexOf('Zero or more repetitions') != -1){
nextRept = true;
continue;
}
if(val == '?')
{ // handle valid param
var attr = false;
if(keys[i].indexOf('@') == 0){
attr = "true";
keys[i] = keys[i].replace("@","");
}
else{
attr = false;
}
tmp.parents.push({name: keys[i].replace("v6:","").replace("@","") , value : val , isAttr : attr , isRepet : nextRept});
isRepet = false;
}
}
}
};
【问题讨论】:
-
你错过了......代码。到目前为止,您尝试过什么?
-
或者不是你尝试了什么,而是你想要做什么?你还没告诉我们,那我们怎么告诉你怎么做呢?
-
我添加了一个小代码示例(还没有递归解决方案)
-
我试图将所有这些 json 放入具有相同层次结构的数组中,这意味着,如果它有子数组,它们将在子数组中,依此类推..
-
我还添加了我当前使用的完整解析代码,它工作到一半......如果级别变深(包含数组等的对象),递归将无法正常工作:/
标签: javascript json parsing recursion