Angular中ng-repeat与ul li的多层嵌套重复问题
学习ng-repeat的过程中常常使用到ng-repeat=”iteminarray”来循环输出所需要的元素,但是当我们需要使用ng-repeat进行多层嵌套时则容易出现数据重复的问题。
如在加载与点击事件于js中进行两次http请求获取data分别为list01[]数组和list02[]赋值再如下显示则会导致it1下每个ul都会重复输出list02[]数组中的内容
{{it1.value}} {{it2.value}}
输出如:
1-1 1-2 1-1 1-2
而非
1-1 1-2 2-1 2-2
其实这个也不是问题,只要换一种思维方式将列表和父级元素相关联形成树状结构就好了
HTML中代码如下
{{it1.name}} {{it2.name}} {{it3.name}} {{it4.name}}
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(varxin$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(varxin$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(varxin$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与ulli的多层嵌套,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!