时间:2021-05-28
学习ng-repeat的过程中常常使用到ng-repeat=”item in array”来循环输出所需要的元素,但是当我们需要使用ng-repeat进行多层嵌套时则容易出现数据重复的问题。
如在加载与点击事件于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-2 1-1 1-2而非
1-1 1-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的多层嵌套,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了AngularJS使用ng-repeat和ng-if实现数据的删选显示效果。分享给大家供大家参考,具体如下:1.首先重复回顾一下ng-repeat
表格数据本质上通常是重复的。ng-repeat指令,可以用来方便地绘制表格。下面的示例说明使用ng-repeat指令来绘制表格。NameMarks{{subje
点击ng-repeat遍历后的li标签,实现更改border颜色;html代码:{{word}}js代码:$scope.li_click=function(i)
前言AngularJS自带指令目前有ng-include、ng-view、ng-switch、ng-repeat。这样的原因是因为,这些指令虽然是Angular
表格数据本质上通常是重复的。ng-repeat指令,可以用来方便地绘制表格。下面的示例说明使用ng-repeat指令来绘制表格。NameMarks{{subje