gpt4 book ai didi

angularjs - 使用 ng-repeat 创建多级列表

转载 作者:行者123 更新时间:2023-12-04 14:47:03 24 4
gpt4 key购买 nike

我正在尝试从包含嵌套数据的对象创建一个多级列表:

function linksRarrange($scope) {
$scope.links = [
{
text: 'Menu Item 1',
url: '#',
},{
text: 'Menu Item 2',
url: '#',
submenu: [
{
text: 'Sub-menu Item 3',
url: '#',
},{
text: 'Sub-menu Item 4',
url: '#',
submenu: [
{
text: 'Sub-sub-menu Item 5',
url: '#',
},{
text: 'Sub-sub-menu Item 6',
url: '#',
}
]
}
]
},{
text: 'Menu Item 3',
url: '#',
}
];
}

为什么这仅输出前 2 级菜单而忽略第三级菜单?
<ul>
<li ng-repeat="link in links"><a href="{{link.url}}">{{link.text}}</a>
<ul>
<li ng-repeat='sublink in link.submenu'><a href="{{sublink.url}}">{{sublink.text}}</a></li>
</ul>
</li>
</ul>

最佳答案

您只看到两个级别,因为您只有两个级别的循环: ng-repeat 只是重复它所给定的内容,并且不会递归地调用自己。

你的第一个循环只是在第一级重复,你的第二个循环只是在第二级重复。您的代码中没有任何内容寻找第 3 级或更深的级别。

您可以递归调用相同的 ng-include,这似乎有效。我已经在 plunker 中演示了这个:http://plnkr.co/edit/NBDgqKOy2qVMQeykQqTY?p=preview

但是该代码使用 ng-init 来复制周围的值是非常可怕的。它有效,但它可能更好地编写为指令。

关于angularjs - 使用 ng-repeat 创建多级列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14812909/

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