AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题


Posted in Javascript onJanuary 21, 2017

本文实例讲述了AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题。分享给大家供大家参考,具体如下:

我们可以使用ng-repeat指令遍历一个JavaScript数组,当数组中有重复元素的时候,AngularJS会报错:

Error: [ngRepeat:dupes] Duplicates in a repeater are not allowed. Use 'track by' expression to specify unique keys. Repeater: user in users, Duplicate key: number:1。下面的代码就会报错:

<html>
 <head>
  <script src="angular-1.2.2/angular.js"></script>
  <script>
     function rootController($scope,$rootScope,$injector)
     {
      $scope.dataList = [1,2,1];
     }
  </script>
 </head>
 <body ng-app ng-controller="rootController">
    <div ng-repeat="data in dataList">
      {{data}}
    </div>
 </body>
</html>

这是因为ng-Repeat不允许collection中存在两个相同Id的对象。

For example: item in items is equivalent to item in items track by $id(item). This implies that the DOM elements will be associated by item identity in the array.

对于数字或者字符串等基本数据类型来说,它的id就是它自身的值。因此数组中是不允许存在两个相同的数字的。为了规避这个错误,需要定义自己的track by表达式。

// 业务上自己生成唯一的id
item in items track by item.id
//或者直接拿循环的索引变量$index来用
item in items track by $index

如果是javascript对象类型数据,那么就算内容一摸一样,ng-repeat也不会认为这是相同的对象。如果将上面的代码中dataList,那么是不会报错的。比如$scope.dataList = [{"age":10},{"age":10}];

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
用于节点操作的API,颠覆原生操作HTML DOM节点的API
Dec 11 Javascript
实现点击列表弹出列表索引的两种方式
Mar 08 Javascript
js确认删除对话框适用于a标签及submit
Jul 10 Javascript
jQuery实现文本框输入同步的方法
Jun 20 Javascript
详解React-Todos入门例子
Nov 08 Javascript
angularjs使用directive实现分页组件的示例
Feb 07 Javascript
基于JS实现翻书效果的页面切换样式
Feb 16 Javascript
JS对象创建的几种方式整理
Feb 28 Javascript
vue.js中使用echarts实现数据动态刷新功能
Apr 16 Javascript
Vue 实现前进刷新后退不刷新的效果
Jun 14 Javascript
React-redux实现小案例(todolist)的过程
Sep 29 Javascript
JavaScript代码模拟鼠标自动点击事件示例
Aug 07 Javascript
微信小程序 九宫格实例代码
Jan 21 #Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 #Javascript
巧用canvas
Jan 21 #Javascript
javascript阻止事件冒泡和浏览器的默认行为
Jan 21 #Javascript
js验证手机号、密码、短信验证码代码工具类
Jun 24 #Javascript
微信小程序 swiper制作tab切换实现附源码
Jan 21 #Javascript
微信小程序之拖拽排序(代码分享)
Jan 21 #Javascript
You might like
用PHP调用Oracle存储过程
2006/10/09 PHP
php _autoload自动加载类与机制分析
2012/02/10 PHP
php读取mysql的简单实例
2014/01/15 PHP
PHP封装函数实现生成随机的字符串验证码
2017/01/24 PHP
php 根据URL下载远程图片、压缩包、pdf等文件到本地
2019/07/26 PHP
JavaScript NaN和Infinity特殊值 [译]
2012/09/20 Javascript
Jquery的hover方法让鼠标经过li时背景变色
2013/09/06 Javascript
extjs 时间范围选择自动判断的实现代码
2014/06/24 Javascript
jQuery中hover方法和toggle方法使用指南
2015/02/27 Javascript
jQuery实现定时读取分析xml文件的方法
2015/07/16 Javascript
基于jquery实现select选择框内容左右移动添加删除代码分享
2015/08/25 Javascript
jQuery实现网页顶部固定导航效果代码
2015/12/24 Javascript
整理AngularJS框架使用过程当中的一些性能优化要点
2016/03/05 Javascript
Node.js数据库操作之连接MySQL数据库(一)
2017/03/04 Javascript
jQuery插件HighCharts绘制简单2D折线图效果示例【附demo源码】
2017/03/21 jQuery
Bootstrap进度条与AJAX后端数据传递结合使用实例详解
2017/04/23 Javascript
JS实现数组按升序及降序排列的方法
2017/04/26 Javascript
underscore之Chaining_动力节点Java学院整理
2017/07/10 Javascript
JQuery EasyUI 结合ztrIee的后台页面开发实例
2017/09/01 jQuery
nuxt+axios解决前后端分离SSR的示例代码
2017/10/24 Javascript
自定义javascript验证框架示例【附源码下载】
2019/05/31 Javascript
基于Vue和Element-Ui搭建项目的方法
2019/09/06 Javascript
Vue之封装公用变量以及实现方式
2020/07/31 Javascript
python读取浮点数和读取文本文件示例
2014/05/06 Python
Python函数可变参数定义及其参数传递方式实例详解
2015/05/25 Python
Python抽象类的新写法
2015/06/18 Python
简单谈谈python的反射机制
2016/06/28 Python
Python 忽略warning的输出方法
2018/10/18 Python
详解pandas数据合并与重塑(pd.concat篇)
2019/07/09 Python
Pytorch 实现数据集自定义读取
2020/01/18 Python
Zooplus葡萄牙:欧洲领先的网上宠物商店
2018/07/01 全球购物
杭州SQL浙江浙大网新恩普软件有限公司
2013/07/27 面试题
租房安全协议书
2014/08/20 职场文书
小英雄雨来观后感
2015/06/09 职场文书
浅谈Redis主从复制以及主从复制原理
2021/05/29 Redis
剑指Offer之Java算法习题精讲二叉树专项训练
2022/03/21 Java/Android