我有一个需求来创建一个水平二叉树结构,它不像我使用ng-repeat
指令看到的典型嵌套。嵌套层次结构的AngularJS ng-include
如何使用ng-include并传递嵌套对象或以某种方式获取我需要的嵌套对象?
下面的代码:
<div id="tree-container" ng-controller="CommentController">
<ul class="root-tree" id="current-tree">
<li class="root node">
<div class="feed">
<div class="comment">{{data.comment}}</div>
</div>
</li>
<li class="root-children">
<ul class="tree" ng-include="'tree'"></ul>
</li>
</ul>
</div>
<script>
app.controller("CommentController", ["$scope", function ($scope) {
$scope.data = {
comments: "blah",
leftChildren: {
comments: ["blah", "blah", "blah"],
leftChildren: { comments: ["blah", "blah", "blah"] },
rightChildren: { comments: ["blah", "blah", "blah"] }
},
rightChildren: { comments: ["blah", "blah", "blah"] }
};
)]);
</script>
<script type="text/ng-template" id="tree">
<li class="node">
<div class="feed">
<div class="comment" ng-repeat="comment in data.leftChildren">{{comment.comment}}</div>
</div>
</li>
<li class="node">
<div class="feed">
<div class="comment" ng-repeat="comment in data.rightChildren">{{comment.comment}}</div>
</div>
</li>
<li class="left-children">
<ul class="tree" ng-include="'tree'"></ul>
</li>
<li class="right-children">
<ul class="tree" ng-include="'tree'"></ul>
</li>
</script>
可以在#tree
模板看到我有2个ng-include
指令。我希望每个嵌套的ng-include
的$scope
都能使用$scope.data
上的层次结构中的下一个层次,这将是leftChildren
和rightChildren
。
换句话说,我基本上想要ng-repeat
在调用$scope
中的嵌套数组时具有相同的效果。
希望这一切有意义:)