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


Posted in Javascript onJuly 24, 2017

学习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的多层嵌套,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
使用onbeforeunload属性后的副作用
Mar 08 Javascript
js创建元素(节点)示例
Jan 02 Javascript
JS 通过系统时间限定动态添加 select option的实例代码
Jun 09 Javascript
BootStrap selectpicker
Jun 20 Javascript
vue双向绑定的简单实现
Dec 22 Javascript
详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例
Feb 17 Javascript
兼容浏览器的js事件绑定函数(详解)
May 09 Javascript
RequireJS用法简单示例
Aug 20 Javascript
详解使用VUE搭建后台管理系统(vue-cli更新至3.0)
Aug 22 Javascript
原生js实现淘宝放大镜效果
Oct 28 Javascript
使用RxJS更优雅地进行定时请求详析
Jun 02 Javascript
vue+vant使用图片预览功能ImagePreview的问题解决
Apr 10 Javascript
深入理解React Native原生模块与JS模块通信的几种方式
Jul 24 #Javascript
浅析JavaScript中的平稳退化(graceful degradation)
Jul 24 #Javascript
vue.js移动端app实战1:初始配置详解
Jul 24 #Javascript
React 子组件向父组件传值的方法
Jul 24 #Javascript
浅谈Node.js ORM框架Sequlize之表间关系
Jul 24 #Javascript
vue 实现 tomato timer(蕃茄钟)实例讲解
Jul 24 #Javascript
jQuery实现拼图小游戏(实例讲解)
Jul 24 #jQuery
You might like
php笔记之:php函数range() round()和list()的使用说明
2013/04/26 PHP
php数组查找函数in_array()、array_search()、array_key_exists()使用实例
2014/04/29 PHP
thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法分析
2019/08/05 PHP
JQuery 技巧和窍门整理(8个)
2010/04/22 Javascript
javascript 词法作用域和闭包分析说明
2010/08/12 Javascript
js拖动div 当鼠标移动时整个div也相应的移动
2013/11/21 Javascript
javaScript如何生成xmlhttp
2013/12/16 Javascript
简介JavaScript中search()方法的使用
2015/06/06 Javascript
jQuery EasyUI datagrid在翻页以后仍能记录被选中行的实现代码
2016/08/15 Javascript
d3.js实现简单的网络拓扑图实例代码
2016/11/06 Javascript
ES6入门教程之Class和Module详解
2017/05/17 Javascript
jQuery.form.js的使用详解
2017/06/14 jQuery
vue-loader教程介绍
2017/06/14 Javascript
js获取地址栏参数的两种方法
2017/06/27 Javascript
基于JavaScript实现无限加载瀑布流
2017/07/21 Javascript
python通过文件头判断文件类型
2015/10/30 Python
python从入门到精通(DAY 2)
2015/12/20 Python
Python内置函数 next的具体使用方法
2017/11/24 Python
Python random模块用法解析及简单示例
2017/12/18 Python
详解python和matlab的优势与区别
2019/06/28 Python
python getopt模块使用实例解析
2019/12/18 Python
使用Python第三方库pygame写个贪吃蛇小游戏
2020/03/06 Python
Django实现将views.py中的数据传递到前端html页面,并展示
2020/03/16 Python
Django Xadmin多对多字段过滤实例
2020/04/07 Python
python框架flask入门之路由及简单实现方法
2020/06/07 Python
python不同版本的_new_不同点总结
2020/12/09 Python
美国领先的奢侈手表在线零售商:WatchMaxx
2017/12/17 全球购物
学习新党章思想汇报
2014/01/09 职场文书
委托协议书范本
2014/04/22 职场文书
党的群众路线教育实践活动总结报告
2014/04/28 职场文书
求职信结尾怎么写
2014/05/26 职场文书
公司经营目标责任书
2015/01/29 职场文书
高中生打架检讨书1000字
2015/02/17 职场文书
2015年班长个人工作总结
2015/04/03 职场文书
HTML+CSS制作心跳特效的实现
2021/05/26 HTML / CSS
CSS的calc函数用法小结
2022/06/25 HTML / CSS