Angular中ng-repeat与ul li的多层嵌套
2017-07-23 23:05
501 查看
学习ng-repeat的过程中常常使用到ng-repeat=”item in array”来循环输出所需要的元素,但是当我们需要使用ng-repeat进行多层嵌套时则容易出现数据重复的问题。
如在加载与点击事件于js中进行两次http请求获取data分别为list01[]数组和list02[]赋值再如下显示则会导致it1下每个ul都会重复输出list02[]数组中的内容
输出如:
而非
其实这个也不是问题,只要换一种思维方式将列表和父级元素相关联形成树状结构就好了
HTML中代码如下
js中代码如下
json文件都是这样的
如在加载与点击事件于js中进行两次http请求获取data分别为list01[]数组和list02[]赋值再如下显示则会导致it1下每个ul都会重复输出list02[]数组中的内容
<ul ng-repeat="it1 in list01"> <li ng-click="show(it1)">{{it1.value}}</li> <ul ng-repeat="it2 in list02"> <li>{{it2.value}}</li> </ul> </ul>
输出如:
1 1-1 1-2 2 1-1 1-2
而非
1 1-1 1-2 2 2-1 2-2
其实这个也不是问题,只要换一种思维方式将列表和父级元素相关联形成树状结构就好了
HTML中代码如下
<ul ng-repeat="it1 in list01"> <li ng-click="show(it1)">{{it1.name}}</li> <ul ng-repeat="it2 in it1.child" ng-show="it1.showChild" style="text-indent:10px;"> <li ng-click="show(it1, it2)">{{it2.name}}</li> <ul ng-repeat="it3 in it2.child" ng-show="it2.showChild" style="text-indent:10px;"> <li ng-click="show(it1, it2, it3)">{{it3.name}}</li> <ul ng-repeat="it4 in it3.child" ng-show="it3.showChild"> <li>{{it4.name}}</li> </ul> </ul> </ul> </ul>
js中代码如下
$http.get('ng01.json').success(function (_data) { $scope.list01 = []; $scope.list01 = _data.data; }); $scope.show = function (it1, it2, it3) { if(it3 != null){ $http.get("ng04.json").success(function (_data) { $scope.list04 = []; $scope.list04 = _data.data; for(var x in $scope.list03){ $scope.list03[x].showChild = false; } it3.showChild = true; it3.child = _data.data; }); return; } if(it2 != null){ $http.get("ng03.json").success(function (_data) { $scope.list03 = []; $scope.list03 = _data.data; for(var x in $scope.list02){ $scope.list02[x].showChild = false; } it2.showChild = true; it2.child = _data.data; }); return; } $http.get("ng02.json").success(function (_data) { $scope.list02 = []; $scope.list02 = _data.data; for(var x in $scope.list01){ $scope.list01[x].showChild = false; } it1.showChild = true; it1.child = _data.data; }); }
json文件都是这样的
{ "success":1, "data":[ {"name":"01"}, {"name":"02"} ] }
相关文章推荐
- Angular中ng-repeat与ul li的多层嵌套重复问题
- AngularJS ng-repeat表格嵌套循环
- Hacking with Angular:如何在深层嵌套ngRepeat中获取不同层级的$index
- angularjs ng-repeat 嵌套 获取上层$index
- AngularJs ng-repeat 嵌套如何获取外层$index
- AngularJS ng-repeat下使用ng-model
- AngularJs ng-repeat性能问题
- angular指令监听ng-repeat渲染完成
- (四上)Angular指令,ng-bind指令,ng-init 指令,ng-click指令,ng-repeat 指令
- AngularJs ng-repeat 必须注意的性能问题
- angularjs select multiple="multiple" ng-repeat
- AngularJS filter:search 是如何匹配的 ng-repeat filter:search ,filter:{$:search},只取repeat的item的value 不含label
- Angular用ng-repeat生成表单并绑定ng-click时的一个细节
- Angular - ng-repeat高级用法
- angularjs ng-repeat下验证问题
- AngularJs ng-repeat
- angular中ng-repeat去重
- angular js ng-repeat实时刷新
- Angularjs Ng_repeat中实现复选框选中并显示不同的样式方法
- AngularJS ng-repeat下使用ng-model