我正在尝试从包含嵌套数据的对象创建一个多级列表:
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级菜单并忽略第3级?
<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>
答案 0 :(得分:7)
你只看到两个级别,因为你只有两个级别的循环:ng-repeat只是重复它给出的,并且不会递归地调用它自己。
你的第一个循环只是在第一个级别重复,而你的第二个循环只在第二级重复。您的代码中没有任何内容可以查找第3级或更深层次。
您可以递归调用相同的ng-include,这似乎有效。我在这里用plunker演示了这个:http://plnkr.co/edit/NBDgqKOy2qVMQeykQqTY?p=preview
但是使用ng-init来复制值时,这段代码非常糟糕。它有效,但它可能更好地作为指令编写。