簡體   English   中英

將嵌套的JSON輸出到 <ul> 帶有子列表項

[英]Output nested JSON into <ul> with sub-list items

我有JSON,但無法將其格式化為帶有子列表項的列表。 我有一些工作,但可能只是缺少一些簡單的東西,希望大家能為我提供幫助。

我的JSON看起來像這樣:

var json = {
    "siteMap": [
        {
            "title": "Red",
            "link": "red.html",
            "subPageArray": [
                { "subTitle": "SubLink1", "link": "test1.html" },
                { "subTitle": "SubLink2", "link": "test2.html" }
            ]
        },
        {
            "title": "Blue",
            "link": "blue.html",
            "subPageArray": [
                { "subTitle": "SubLink1", "link": "test1.html" },
                { "subTitle": "SubLink2", "link": "test2.html" }
            ]
        },
        {
            "title": "Green",
            "link": "green.html"
        },
        {
            "title": "Yellow",
            "link": "yellow.html",
            "subPageArray": [
                { "subTitle": "SubLink1", "link": "test1.html" },
                { "subTitle": "SubLink2", "link": "test2.html" }
            ]
        }
    ]
}

如果對象沒有'subPageArray',我希望該項目下沒有子列表。

我的jQuery看起來像這樣:

$.each(json.siteMap, function (i, val) {
    var i = 0,
        a = i++,
        data = "<li class='topLevel'><a href='/" + this.link + "'>" + this.title + "</a><ul><li class='subLevel'><a href='/" + this.subPageArray[i].link + "'>" + this.subPageArray[a].subTitle + "</a></li></ul></li>";
        i++;    
        $(data).appendTo(".siteMapContent ul");
});

我的HTML看起來像這樣:

<div class="siteMapContent">
    <ul></ul>
</div>

我希望最終結果將如下所示:

<ul>
    <li><a href="red.html">Red</a>
        <ul>
            <li><a href="test1.html">SubLink1</a></li>
            <li><a href="test2.html">SubLink2</a></li>
        </ul>
    </li>
    <li><a href="blue.html">Blue</a>
        <ul>
            <li><a href="test1.html">SubLink1</a></li>
            <li><a href="test2.html">SubLink2</a></li>
        </ul>
    </li>
    <li><a href="green.html">Green</a></li>
    <li><a href="yellow.html">Yellow</a>
        <ul>
            <li><a href="test1.html">SubLink1</a></li>
            <li><a href="test2.html">SubLink2</a></li>
        </ul>
    </li>
</ul>

這不是最干凈的方法,但是可以完成工作http://jsfiddle.net/8k6nw/

如果存在,您當然需要遍歷子項目。

var html = "<ul>";

json.siteMap.forEach(function(item) {

    html += "<li><a href='"+item.link+"'>"+item.title+"</a>";

    if (item.subPageArray) {

        html += "<ul>";

        item.subPageArray.forEach(function(subitem) {

              html += "<li><a href='"+subitem.link+"'>"+subitem.subTitle+"</a></li>";      

        });

        html += "</ul>";

    }

    html += "</li>";
});

document.body.innerHTML = html + "</ul>";
$.each(json.siteMap, function (i, val) {
    var data="<li class='topLevel'><a href='/" + this.link + "'>" + this.title + "</a><ul>";
    if(this.subPageArray!=undefined){  // TO check if subPageArray exists here in case of Green
       for (i = 0; i < this.subPageArray.length; ++i) {
           //Adding the internal li
            data += "<li class='subLevel'><a href='/" + this.subPageArray[i].link + "'>" + this.subPageArray[i].subTitle + "</a></li>";
       }
    }
       data+="</ul></li>";

        $(data).appendTo(".siteMapContent .hii");
});

和您的html代碼:我為ul添加了一個類名,因此動態生成的代碼不會添加到內部ul

<div class="siteMapContent">
    <ul class="hii"></ul>
</div>

工作提琴: http : //jsfiddle.net/Hp8ZY/3/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM