我正在设计一个带有jquery的类别系统,我可以在多维数组中插入值,然后使用jquery将它们附加到某个html页面。我遇到了一个问题,我每次向阵列添加更多元素时都需要更新代码。
var arr = [];
arr =
{
"a":{
"d":"value",
"e":"value",
"f":"value",
"g":{"some value":[1, 2, 3]}
},
"b":{
"value1":"value",
"value2":{"aaa":{"sss": "ddd"}, "bbb":{"eee": "ddd"}},
"value3":"value vvv"
},
"c":[1, 2, 3]
};
我想将数组的元素追加到html页面,所以结果如下所示:
-a
--d
---value
--e
---value
--f
---value
--g
---some value
----1
----2
----3
-b
--value1
---value
--value2
---aaa
----sss
----ddd
---bbb
----eee
----ddd
--value3
---value vvv
-c
--1
--2
--3
我想编写一系列$ .each语句来遍历任何多维数组(具有x个级别)并附加其元素,如上所示。我遇到的问题是我得到[object Object]值并且我理解为什么,但我需要获取并追加所有元素。我不知道如何编写$ .each语句。
这是我试过的
$.each(arr, function(idx, obj){
$("#categories").append("--"+obj+"<br>");
$.each(obj, function(key, value){
$("#categories").append("--"+value+"<br>");
//keep going with the each statements and check if the elements are objects
});
});
抱歉我的英文。
答案 0 :(得分:2)
这是一个为你做这个的小提琴 - 我已经稍微重新设置了你的回报,因为让字符串下面返回的值进一步缩进是没有意义的。然后你无法判断它是关键还是值。
var indent = "";
function myFunction(obj) {
indent += '-';
for (var key in obj) {
x = obj[key];
if ($.isPlainObject(x)) {
$('#categories').append(indent + key + '<br />');
myFunction(x);
} else {
$('#categories').append(indent + key + '<br />');
if (typeof x === 'object') {
for (var key in x) {
$('#categories').append(indent + '-' + x[key] + '<br />');
}
} else {
$('#categories').append(indent + '-' + x + '<br />');
}
}
}
indent = indent.substring(0, indent.length - 1);
}
myFunction(arr);
答案 1 :(得分:1)
几分钟后,我做到了。
$.each(arr, function(idx, obj){
$("#categories").append("-"+idx+"<br>");
for(var i in obj)
{
if (typeof (obj[i])!='number')
$("#categories").append("--"+i+"<br>");
if(typeof (obj[i])==='object')
{
for(var j in obj[i])
{
$("#categories").append("---"+j+"<br>");
var len =obj[i][j].length;
if(typeof len=='undefined')
{
for (var m in obj[i][j])
$("#categories").append("----"+m+"<br>");
$("#categories").append("----"+obj[i][j][m]+"<br>");
}
else
{
for(var k=0;k<obj[i][j].length;k++)
{
$("#categories").append("----"+obj[i][j][k]+"<br>");
}
}
}
}
else
{
$("#categories").append("---"+obj[i]+"<br>");
}
}
});
这是一个示例Fiddle