91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-21 04:04:38 來源:腳本之家 閱讀:116 作者:aitangyong 欄目:web開發

本文實例講述了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程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

抚顺县| 闽侯县| 呈贡县| 淳化县| 吉木萨尔县| 陈巴尔虎旗| 昌乐县| 肇庆市| 营口市| 南华县| 汤阴县| 农安县| 乌鲁木齐市| 永春县| 本溪| 湘潭县| 宁化县| 云南省| 抚顺县| 日照市| 灵川县| 广灵县| 九江县| 年辖:市辖区| 黄平县| 疏勒县| 元氏县| 浮山县| 洮南市| 尤溪县| 运城市| 手游| 洛川县| 北流市| 杭锦后旗| 常熟市| 中西区| 平阴县| 三河市| 鄯善县| 湖南省|