源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Angular中ng-repeat与ul li的多层嵌套重复问题

  • 时间:2020-05-27 03:48 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Angular中ng-repeat与ul li的多层嵌套重复问题
学习ng-repeat的过程中常常使用到[code]ng-repeat=”item in array”[/code]来循环输出所需要的元素,但是当我们需要使用[code]ng-repeat[/code]进行多层嵌套时则容易出现数据重复的问题。 如在加载与点击事件于js中进行两次http请求获取data分别为[code]list01[][/code]数组和[code]list02[][/code]赋值再如下显示则会导致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的多层嵌套,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部