国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

AngularJS ng-repeat指令中使用track by子語句解決重復數據遍歷錯誤問題

2019-11-19 17:49:50
字體:
來源:轉載
供稿:網友

本文實例講述了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相關內容感興趣的讀者可查看本站專題:《AngularJS入門與進階教程》及《AngularJS MVC架構總結

希望本文所述對大家AngularJS程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 呼和浩特市| 夹江县| 永城市| 墨江| 红桥区| 康乐县| 岳普湖县| 永吉县| 关岭| 吕梁市| 永登县| 安阳市| 合水县| 健康| 永和县| 安阳县| 阿尔山市| 余干县| 东台市| 乌兰察布市| 于田县| 鄂州市| 荥阳市| 睢宁县| 麟游县| 凌云县| 左贡县| 温州市| 贵定县| 汉沽区| 临夏县| 焉耆| 佛教| 普兰店市| 科技| 锦屏县| 寻乌县| 海晏县| 新河县| 株洲市| 伊金霍洛旗|