aboutsummaryrefslogtreecommitdiffstats
path: root/docs/content/error
diff options
context:
space:
mode:
Diffstat (limited to 'docs/content/error')
-rw-r--r--docs/content/error/$rootScope/infdig.ngdoc24
1 files changed, 24 insertions, 0 deletions
diff --git a/docs/content/error/$rootScope/infdig.ngdoc b/docs/content/error/$rootScope/infdig.ngdoc
index e36f1d69..d6261df1 100644
--- a/docs/content/error/$rootScope/infdig.ngdoc
+++ b/docs/content/error/$rootScope/infdig.ngdoc
@@ -14,4 +14,28 @@ $scope.$watch('foo', function() {
});
```
+One common mistake is binding to a function which generates a new array every time it is called. For example:
+
+```
+<div ng-repeat="user in getUsers()">{{ user.name }}</div>
+
+...
+
+$scope.getUsers = function() {
+ return [ { name: 'Hank' }, { name: 'Francisco' } ];
+};
+```
+
+Since `getUsers()` returns a new array, Angular determines that the model is different on each `$digest`
+cycle, resulting in the error. The solution is to return the same array object if the elements have
+not changed:
+
+```
+var users = [ { name: 'Hank' }, { name: 'Francisco' } ];
+
+$scope.getUsers = function() {
+ return users;
+});
+```
+
The maximum number of allowed iterations of the `$digest` cycle is controlled via TTL setting which can be configured via {@link ng.$rootScopeProvider $rootScopeProvider}.