您好,登錄后才能下訂單哦!
學習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" > <li ng-click="show(it1, it2)">{{it2.name}}</li> <ul ng-repeat="it3 in it2.child" ng-show="it2.showChild" > <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的多層嵌套,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。