6

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

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>
4

1 回答 1

7

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

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

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

但是使用 ng-init 复制值的代码非常糟糕。它可以工作,但最好将其写为指令。

于 2013-02-11T14:34:19.307 回答