Frage

I have

Myitem1.MyFunc();
Myitem2.MyFunc();

function MyFunc(){
  if (okToUpdate){
    //we weren't here from anywhere within the last 100 milliseconds
  }
}

Unfortunately, okToUpdate variable is updated not immediately, so it needs at least 100 milliseconds from the previous call of the function to have the correct value. How to make MyFunc be executed with the delay?

War es hilfreich?

Lösung

setTimeout(function(){
       Myitem1.MyFunc();
},100)

will do the trick. If you explain what you want exactly I can give you exact timing code.

Andere Tipps

This code may help you

var clrTime=null;

MyFunc(){
    clrTime=setTimeout(function(){
        if (okToUpdate){
            // your code to do 
        }
    },100);
}

Using callbacks or promises would be the clean solution. Not some kind of busy waiting implemented with timeouts.

Have a look into publish/subscribe pattern.

I would use the setTimeout() function. Something like this:

<script>
function myFunction() {
    setTimeout(function(){MyFunc()},100);
}
</script>

<body onload="myFunction()">
</body>

setTimeout() method

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top