原因及現象
我們可以使用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表達式。
// 業務上自己生成唯一的iditem in items track by item.id
//或者直接拿循環的索引變量$index來用item in items track by $index
如果是javascript對象類型數據,那么就算內容一摸一樣,ng-repeat也不會認為這是相同的對象。如果將上面的代碼中dataList,那么是不會報錯的。比如$scope.dataList = [{"age":10},{"age":10}];
解決辦法
- 在循環的數組后面加上 track by $index 即可以完美解決
<li ng-repeat="x in names track by $index">