Angular中ng-repeat與ul li的多層嵌套重復(fù)問題
學(xué)習(xí)ng-repeat的過程中常常使用到ng-repeat=”item in array”來循環(huán)輸出所需要的元素,但是當(dāng)我們需要使用ng-repeat進(jìn)行多層嵌套時(shí)則容易出現(xiàn)數(shù)據(jù)重復(fù)的問題。
如在加載與點(diǎn)擊事件于js中進(jìn)行兩次http請求獲取data分別為list01[]數(shù)組和list02[]賦值再如下顯示則會導(dǎo)致it1下每個(gè)ul都會重復(fù)輸出list02[]數(shù)組中的內(nèi)容
<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
其實(shí)這個(gè)也不是問題,只要換一種思維方式將列表和父級元素相關(guān)聯(lián)形成樹狀結(jié)構(gòu)就好了
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"}
]
}
總結(jié)
以上所述是小編給大家介紹的Angular中ng-repeat與ul li的多層嵌套,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
AngularJS基礎(chǔ) ng-keydown 指令簡單示例
本文主要介紹AngularJS ng-keydown 指令,在這里幫大家整理了ng-keydown 指令的基礎(chǔ)資料,并附有代碼,有需要的朋友可以參考下2016-08-08
詳解angularjs結(jié)合pagination插件實(shí)現(xiàn)分頁功能
本篇文章主要介紹了詳解angularjs結(jié)合pagination插件實(shí)現(xiàn)分頁功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02
Angular.JS讀取數(shù)據(jù)庫數(shù)據(jù)調(diào)用完整實(shí)例
這篇文章主要介紹了Angular.JS讀取數(shù)據(jù)庫數(shù)據(jù)調(diào)用,結(jié)合完整實(shí)例形式分析了AngularJS使用$http.get方法與后臺php交互讀取數(shù)據(jù)庫數(shù)據(jù)相關(guān)操作技巧,需要的朋友可以參考下2019-07-07
angular6.0使用教程之父組件通過url傳遞id給子組件的方法
這篇文章主要介紹了angular6.0使用教程之父組件通過url傳遞id給子組件的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06
探索angularjs+requirejs全面實(shí)現(xiàn)按需加載的套路
這篇文章主要探索了angularjs+requirejs全面實(shí)現(xiàn)按需加載的套路,圍繞angularjs提供的各種機(jī)制進(jìn)行研究,感興趣的小伙伴們可以參考一下2016-02-02
對比分析AngularJS中的$http.post與jQuery.post的區(qū)別
這篇文章主要給大家對比分析AngularJS中的$http.post與jQuery.post的區(qū)別,十分的詳細(xì),是篇非常不錯(cuò)的文章,這里推薦給小伙伴們。2015-02-02

