setInterval() behaviour with 0 milliseconds in JavaScript

前端 未结 4 953
孤独总比滥情好
孤独总比滥情好 2020-11-27 21:18

In my application I found some JavaScript code that is using setInterval with 0 milliseconds, like so:

self.setInterval(\"myFunction()\",0);


        
相关标签:
4条回答
  • 2020-11-27 21:18

    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.

    0 讨论(0)
  • 2020-11-27 21:31

    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.

    0 讨论(0)
  • 2020-11-27 21:39

    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.

    0 讨论(0)
  • 2020-11-27 21:45

    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.

    0 讨论(0)
提交回复
热议问题