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 相关文章推荐
静态页面的值传递(三部曲)
Sep 25 Javascript
js改变文章字体大小的实例代码
Nov 27 Javascript
Javascript中的call()方法介绍
Mar 15 Javascript
JQuery操作textarea,input,select,checkbox方法
Sep 02 Javascript
js和jquery分别验证单选框、复选框、下拉框
Dec 17 Javascript
简单实现jQuery轮播效果
Aug 18 jQuery
Angular弹出模态框的两种方式
Oct 19 Javascript
C#实现将一个字符转换为整数
Dec 12 Javascript
vue项目总结之文件夹结构配置详解
Dec 13 Javascript
完美解决手机网页中输入框被输入法遮挡的问题
Dec 19 Javascript
VSCode搭建Vue项目的方法
Apr 30 Javascript
uniapp实现横向滚动选择日期
Oct 21 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异常处理使用示例
2014/02/25 PHP
THINKPHP2.0到3.0有哪些改进之处
2015/01/04 PHP
PHP仿微信发红包领红包效果
2016/10/30 PHP
php实现基于pdo的事务处理方法示例
2017/07/21 PHP
thinkphp3.2同时连接两个数据库的简单方法
2019/08/13 PHP
浅谈laravel框架与thinkPHP框架的区别
2019/10/23 PHP
jquery 必填项判断表单是否为空的方法
2008/09/14 Javascript
js禁止页面使用右键(简单示例代码)
2013/11/13 Javascript
jquery图片轮播插件仿支付宝2013版全屏图片幻灯片
2014/04/03 Javascript
JavaScript鼠标事件,点击鼠标右键,弹出div的简单实例
2016/08/03 Javascript
jQuery Ajax 实现分页 kkpager插件实例代码
2017/08/10 jQuery
详解Vue Elememt-UI构建管理后台
2018/02/27 Javascript
默认浏览器设置及vue自动打开页面的方法
2018/09/21 Javascript
分享5个小技巧让你写出更好的 JavaScript 条件语句
2018/10/20 Javascript
JavaScript 中 JSON.parse 函数 和 JSON.stringify 函数
2018/12/05 Javascript
Vue-Cli 3.0 中配置高德地图的两种方式
2019/06/19 Javascript
使用Vue.js中的过滤器实现幂方求值的方法
2019/08/27 Javascript
vue mvvm数据响应实现
2020/11/11 Javascript
Python实现曲线拟合操作示例【基于numpy,scipy,matplotlib库】
2018/07/12 Python
Python实现正整数分解质因数操作示例
2018/08/01 Python
对python 命令的-u参数详解
2018/12/03 Python
在Pycharm中修改文件默认打开方式的方法
2019/01/17 Python
pygame实现俄罗斯方块游戏(对战篇1)
2019/10/29 Python
在Python IDLE 下调用anaconda中的库教程
2020/03/09 Python
快速解决Django关闭Debug模式无法加载media图片与static静态文件
2020/04/07 Python
Python导入数值型Excel数据并生成矩阵操作
2020/06/09 Python
Python 爬虫性能相关总结
2020/08/03 Python
CSS3线性渐变简单实现以及该属性在浏览器中的不同
2012/12/12 HTML / CSS
使用CSS禁止textarea调整大小功能的方法
2015/03/13 HTML / CSS
Raffaello Network德国:意大利拉斐尔时尚购物网
2019/05/01 全球购物
银行实习生的自我评价
2014/01/13 职场文书
2014爱耳日宣传教育活动总结
2014/03/09 职场文书
高中生第一学年自我鉴定2015
2014/09/28 职场文书
2015年语文教学工作总结
2015/05/25 职场文书
班主任开场白
2015/06/01 职场文书
redis使用不当导致应用卡死bug的过程解析
2021/07/01 Redis