In my application I found some JavaScript code that is using setInterval
with 0 milliseconds, like so:
self.setInterval(\"myFunction()\",0);
Browser set a minimal value for the interval. Usualy 10ms, but it can depend on the browser. This means repeat this as fast as I'm possibly allowed. The W3C spec say 4ms : http://www.whatwg.org/specs/web-apps/current-work/multipage/timers.html#timers
This is correct but probably reveal a design error.
EDIT: By the way, it is bad practice to pass a string to setTimeout/setInterval, pass a function instead as javascript has first class functions.
setInterval(myFunction, 0)
calls myFunction
continuously with minimum delay. It is almost like calling myFunction
in a infinite loop. Except that here you can stop the loop using the clearInterval
method.
I assume that in myFunction()
there is a clearInterval
.
Basically, you've set an interval that can happen as often as possible. If the browser executing JavaScript actually gets to the clearInterval
part before the next iteration of the interval, then it will be fine. Otherwise, it will happen again and again.
Use setTimeout
instead.
To have it executed only once with minor delay, use setTimeOut
instead:
window.setTimeout(myFunction, 10);
As you're using AJAX, you don't have to use any timers at all - just call the next AJAX request in the Callback (complete/success event) of the current AJAX request.
Post your current code and we might be able to guide you further.