jQuery JSON 循环遍历嵌套对象

IT技术 javascript jquery json
2021-02-25 14:28:10

我目前有这个:

    $.getJSON('test.json', function(data) {
      var items = [];

      $.each(data, function(key, val) {
        items.push('<li id="' + key + '">' + val + '</li>');
      });

      $('<ul/>', {
        'class': 'my-new-list',
        html: items.join('')
      }).appendTo('body');
    });

test.json 看起来像这样:

{"key1":{"key11":"value11","key12":"value12"},"key2":"value2","key3":"value3"}

我越来越:

[object Object]
value2
value3

如何更改它以便它遍历所有嵌套项而不管我有多少嵌套值?

所以对于上面的例子,我会得到

value1
    value11
    value12
value2
value3
2个回答

您可以创建递归循环函数,但会遇到问题:当属性是对象时,由于没有字符串,因此没有文本可显示。所以,你最终会得到:

- - value11
  - value12
- value2
- value3

因为 whilevalue2是为项目 #2 显示的字符串,它是为项目 #1 显示的对象。

无论如何,这就是我编造的:http : //jsfiddle.net/uXww2/

// obj is the object to loop, ul is the ul to append lis to
function loop(obj, ul) {
    $.each(obj, function(key, val) {
        if(val && typeof val === "object") { // object, call recursively
            var ul2 = $("<ul>").appendTo(
                $("<li>").appendTo(ul)
            );

            loop(val, ul2);
        } else {
            $("<li>", {
                id: key
            }).text(val).appendTo(ul);
        }
    });
}

$.getJSON('test.json', function(data) {
  var ul = $("<ul>");

  loop(data, ul);

  ul.addClass("my-new-list").appendTo('body');
});
这不考虑数组,你可能应该写 $.isPlainObject(val) || $.isArray(val)
2021-04-21 14:28:10
@克里斯托夫:是的。OP 只处理字符串,虽然(没有数组/ null/ 等),但我会编辑。
2021-04-21 14:28:10
@Or W:您必须为 ul2 中的 li 提供一些文本(关键变量)。
2021-04-22 14:28:10
使用typeof不推荐的,因为typeof null === "object"产生true
2021-04-27 14:28:10
谢谢,如果存在嵌套值,是否可以将键用作顶部 <li> 内容?
2021-05-17 14:28:10

所以,你想要的是一个循环遍历 json 对象的树视图

你可以使用我递归制作的这段代码,测试一下;)

var treestring      = "";
var myid            = "arv";
var json_object     = {your json}; 

var Tree = function (data) {
   this.data = data;
};

//1st step
Tree.renderTree(json_object, myid);

//2st step , this is a function
Tree.renderTree= function (json_object, myid) {
    $.each(json_object, function (key, val) {
        var m = new Tree(val);
        m.render(myid);
    });       
}

//3st step, this a function too
Tree.prototype.render = function (myid) {
    treestring = "<li class='category'> " + this.data.Name;
    //Check if has another arrays inside the current
    if (this.data.SubFolders) {
        treestring += "<ul id=" + this.data.ID + "</ul>";
        $("#" + myid).append(treestring);
        myid = this.data.ID;
        Tree.renderTree(this.data.Sub_Fodlers, myid);
    }
    else {
        treestring += "</li>";
        $("#" + myid).append(treestring);
    }
};


//HTML
<div id="tree"> 
     <ul id="arv"></ul>
</div>

//this.data.{something} 吃了你的 json 对象中定义的字段

请享用 ;)