最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - "10 $digest() iterations reached. Aborting!" due to filter using angularjs - Stack Overflow

programmeradmin1浏览0评论

Take a look at the following:

.html

when you type "a" in the input box, you obtain the 10 $digest() iterations reached. Aborting! error.

Do you have any idea, why that happens?

EDIT: Here is the code that makes problems:

EDIT: It looks like it is a problem of Song.clone. If I replace it by angular.copy, then it works. Anybody could explain that?

Here is the working version:

Take a look at the following:

https://dl.dropbox./u/4571/musicopeTypescript/musicopeTypescript/index.html

when you type "a" in the input box, you obtain the 10 $digest() iterations reached. Aborting! error.

Do you have any idea, why that happens?

EDIT: Here is the code that makes problems:

http://embed.plnkr.co/PTkvPc

EDIT: It looks like it is a problem of Song.clone. If I replace it by angular.copy, then it works. Anybody could explain that?

Here is the working version:

http://plnkr.co/edit/8Jk1pR?p=preview

Share Improve this question edited Nov 8, 2012 at 6:19 Oldrich Svec asked Nov 7, 2012 at 20:20 Oldrich SvecOldrich Svec 4,2312 gold badges30 silver badges55 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 4

Is your filter modifying the original data somehow? That's the only specific thing that looks like it would cause the infinite digest cycle.

EDIT: in regards to different cloning functions lead to different behavior.

I suspect one is doing deep cloning, the other is not, and in one case AngularJS is checking object equality and your filter is creating new objects each time, causing the problem.

I'd suggest breaking up some of that logic and perhaps moving some of it into the controller or additional filters. The filter that narrows down your array should only be doing that, and just return references to the original objects. Then you can write other filters to manipulate the tags, etc.

Also +1 for Abba. :P

To understand why is this is happening, it's good to understand how angular works runtime. Basically there are watchers that keep returning back different values, and so it keeps going through the $digest loop and then stops it from infinitely looping. From their $digest() documentation:

Process all of the watchers of the current scope and its children. Because a watcher's listener can change the model, the $digest() keeps calling the watchers until no more listeners are firing. This means that it is possible to get into an infinite loop. This function will throw 'Maximum iteration limit exceeded.' if the number of iterations exceeds 10.

Without knowing what your code is doing, it's hard to give a specific solution to why this is happening in your case, but this should answer your questions as to when this error is thrown.

发布评论

评论列表(0)

  1. 暂无评论