如何使用AngularJS处理数据的递归渲染

我有一个应用程序,该应用程序具有一组具有递归关系的数据(使用递归的树状视图。)我尝试了几种通过Angular实现此关系的方法,但似乎都没有一种可行的结果。

这里的想法是,我希望使用一组嵌套列表来呈现此数据,以允许许多(7+)深度级别。为了简化操作(我的实际应用程序使用Restangular),我构建了以下插件:

http://plnkr.co/edit/dKT9OvpsMgnxmLwgF0ij

虽然“顶层”数据正确呈现(只是第一个标题),但我使用嵌套控制器递归的尝试似乎失败了。这里的想法是,树中的每个“子代”都使用其自己的控制器进行渲染,然后控制器可以依次渲染其子代。我意识到嵌套控制器可能不是“最佳”方法,但是经过大量搜索之后,我还没有找到“更好”的选择。

重要的是,所得解决方案在此保留“嵌套”的概念(每个元素都出现在其父元素下方,并带有轻微的缩进)。

回答:

而不是嵌套您的控制器,而是嵌套数据并仅拥有一个控制器。

该视图由递归引用自己的模板处理。

正如chadermani所链接的那样,那里有一些答案。

这是一个很好的例子的小提琴(不是我的代码)

http://jsfiddle.net/brendanowen/uXbn6/8/

和小提琴中的代码

<script type="text/ng-template"  id="tree_item_renderer.html">

{{data.name}}

<button ng-click="add(data)">Add node</button>

<button ng-click="delete(data)" ng-show="data.nodes.length > 0">Delete nodes</button>

<ul>

<li ng-repeat="data in data.nodes" ng-include="'tree_item_renderer.html'"></li>

</ul>

</script>

<ul ng-app="Application" ng-controller="TreeController">

<li ng-repeat="data in tree" ng-include="'tree_item_renderer.html'"></li>

</ul>

angular.module("myApp", []).

controller("TreeController", ['$scope', function($scope) {

$scope.delete = function(data) {

data.nodes = [];

};

$scope.add = function(data) {

var post = data.nodes.length + 1;

var newName = data.name + '-' + post;

data.nodes.push({name: newName,nodes: []});

};

$scope.tree = [{name: "Node", nodes: []}];

}]);

以上是 如何使用AngularJS处理数据的递归渲染 的全部内容, 来源链接: utcz.com/qa/402659.html

回到顶部