[removed] Is it ok to call cleartimeout before set

2019-04-03 22:10发布

问题:

I have a function that sets a timer, and calls itself back upon expiration of the timer.

What I'd like to know is if it is bad practice to clear the timer at the top of the function.

The reason for this is because I will be calling that function asynchronously from time to time, and if I don't clear the timer first, I'll have two running simultaneously.

I realize that I can clear the timer right before I make the other call to the function, but I'm wondering if it will cause problems in any browser if I just keep the cleartimeout call inside the function which contains the timer.

One other thought - Can I test the timer variable before making the cleartimeout call, to see if it is a timer?

Here is some example code:

function onAir(){

    // reset timer  
    clearTimeout(timer);

    $.getJSON("http://mywebsite.com?format=json&callback=?",function(data){
        if(data.result == '1'){
            do stuff here   
        }
        else{
            do other stuff here
        }   
    });

    // start timer
    timer = setTimeout("onAir()",60000);
} 

Thanks for sharing your brain with me!

Kenny

回答1:

Yes, that's fine. Also, you should call "setTimeout()" like this:

  timer = setTimeout(onAir, 60000);


回答2:

Yes you can call clearTimeout on a nullvariable.

Also i would suggest you change your setTimeout so it won't use eval:

timer = setTimeout(onAir,60000);


回答3:

Yes you can call clearTimeout(timer), but there are some edge cases where it may cause issues.

If timer had been previously set with some other integer value, you might be killing off a completely unrelated timer.

setTimeout just returns an integer index for the timer. If you're not sure if a timer has been previously set, you could add a check before calling clearTimeout:

if (window.timer)
{
  clearTimeout(timer);
}
...
timer = setTimeout(onAir, duration);

A solution to the possible pollution of the timer variable is to use a closure:

(function(){
  var timer,
    duration;
  duration = 60000;
  window.onAir = function onAir(){
    ...code...
    if (timer){
      clearTimeout(timer);
    }
    timer = setTimeout(onAir,duration);
  };
});


回答4:

Yes, you can call a clearTimeout on a null variable and the world won't implode.



回答5:

Clearing a Timeout raises not problem to me (but i am not a javascript guru).

Btw, you can find intersting things (checking an existing Timeout) on this thread: Check if a timeout has been cleared?