gpt4 book ai didi

javascript - 根据菜单项的URL路径结构创建嵌套的UL菜单

转载 作者:数据小太阳 更新时间:2023-10-29 04:32:49 26 4
gpt4 key购买 nike

我有一个菜单项数组,每个菜单项都包含名称和 URL,如下所示:

var menuItems = [  
{
name : "Store",
url : "/store"
},
{
name : "Travel",
url : "/store/travel"
},
{
name : "Gardening",
url : "/store/gardening"
},
{
name : "Healthy Eating",
url : "/store/healthy-eating"
},
{
name : "Cook Books",
url : "/store/healthy-eating/cook-books"
},
{
name : "Single Meal Gifts",
url : "/store/healthy-eating/single-meal-gifts"
},
{
name : "Outdoor Recreation",
url : "/store/outdoor-recreation"
},
{
name : "Hiking",
url : "/store/outdoor-recreation/hiking"
},
{
name : "Snowshoeing",
url : "/store/outdoor-recreation/hiking/snowshoeing"
},
{
name : "Skiing",
url : "/store/outdoor-recreation/skiing"
},
{
name : "Physical Fitness",
url : "/store/physical-fitness"
},
{
name : "Provident Living",
url : "/store/provident-living"
}
]

我一直在尝试将它呈现为一个无序列表,但没有成功,它具有一个遵循 URL 路径结构的嵌套 UL 结构,如下所示:

<ul>  
<li><a href="/store">Store</a>
<ul>
<li><a href="/store/travel">Travel</a></li>
<li><a href="/store/gardening">Gardening</a></li>
<li><a href="/store/healthy-eating">Healthy Eating</a>
<ul>
<li><a href="/store/healthy-eating/cook-books">Cook Books</a></li>
<li><a href="/store/healthy-eating/single-meal-gifts">Single Meal Gifts</a></li>
</ul>
</li>
<li><a href="/store/outdoor-recreation">Outdoor Recreation</a>
<ul>
<li><a href="/store/outdoor-recreation/hiking">Hiking</a>
<ul>
<li><a href="/store/outdoor-recreation/hiking/snowshoeing">Snowshoeing</a></li>
</ul>
</li>
<li><a href="/store/outdoor-recreation/skiing">Skiing</a></li>
</ul>
</li>
<li><a href="/store/physical-fitness">Physical Fitness</a></li>
<li><a href="/store/provident-living">Provident Living</a></li>
</ul>
</li>
</ul>

我见过的所有示例都以反射(reflect)父子关系的数据结构(例如 xml 或 JSON)开始,但我很难将其从 URL 中提取出来并使用它来呈现新结构。

如果有人可以指导我如何使用 jQuery 执行此操作,我将非常感激。我意识到我可能需要使用一些递归函数或者 jQuery 模板,但这些东西对我来说还是有点新鲜。
谢谢

最佳答案

我认为最好的解决方案是首先将您的数据结构转换为具有父/子关系的树结构。渲染这个结构会更容易,因为 UL 本身有一个树结构。

您可以使用这两个函数转换菜单项

// Add an item node in the tree, at the right position
function addToTree( node, treeNodes ) {

// Check if the item node should inserted in a subnode
for ( var i=0; i<treeNodes.length; i++ ) {
var treeNode = treeNodes[i];

// "/store/travel".indexOf( '/store/' )
if ( node.url.indexOf( treeNode.url + '/' ) == 0 ) {
addToTree( node, treeNode.children );

// Item node was added, we can quit
return;
}
}

// Item node was not added to a subnode, so it's a sibling of these treeNodes
treeNodes.push({
name: node.name,
url: node.url,
children: []
});
}

//Create the item tree starting from menuItems
function createTree( nodes ) {
var tree = [];

for ( var i=0; i<nodes.length; i++ ) {
var node = nodes[i];
addToTree( node, tree );
}

return tree;
}

var menuItemsTree = createTree( menuItems );
console.log( menuItemsTree );

生成的 menuItemsTree 将是这样的对象

[
{
"name":"Store",
"url":"/store",
"children":[
{
"name":"Travel",
"url":"/store/travel",
"children":[

]
},
{
"name":"Gardening",
"url":"/store/gardening",
"children":[

]
},
{
"name":"Healthy Eating",
"url":"/store/healthy-eating",
"children":[
{
"name":"Cook Books",
"url":"/store/healthy-eating/cook-books",
"children":[

]
},
{
"name":"Single Meal Gifts",
"url":"/store/healthy-eating/single-meal-gifts",
"children":[

]
}
]
},
{
"name":"Outdoor Recreation",
"url":"/store/outdoor-recreation",
"children":[
{
"name":"Hiking",
"url":"/store/outdoor-recreation/hiking",
"children":[
{
"name":"Snowshoeing",
"url":"/store/outdoor-recreation/hiking/snowshoeing",
"children":[

]
}
]
},
{
"name":"Skiing",
"url":"/store/outdoor-recreation/skiing",
"children":[

]
}
]
},
{
"name":"Physical Fitness",
"url":"/store/physical-fitness",
"children":[

]
},
{
"name":"Provident Living",
"url":"/store/provident-living",
"children":[

]
}
]
}
]

您提到您已经有了树的 html 渲染器,对吗?如果您需要进一步的帮助,请告诉我们!

关于javascript - 根据菜单项的URL路径结构创建嵌套的UL菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7133657/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com