摘要:在写H5游戏时经常需要使用定时刷新页面实现动画效果,比较常用即setTimeout()以及setInterval() setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则是在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。
在写H5游戏时经常需要使用定时刷新页面实现动画效果,比较常用即setTimeout()以及setInterval()
setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则是在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。也就是说setTimeout()只执行一次,setInterval()可以执行多次。两个函数的参数也相同,第一个参数是要执行的code或句柄,第二个是延迟的毫秒数
setTimeout
描述
vartimeoutID =window.setTimeout(code,millisec);
timeoutID:定时器ID号,它可以在clearTimeout()函数中被用来清除定时器。
code:一个被执行的代码串或函数
millisec:延迟的时间,单位毫秒。如果没有指定,默认为0
setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式
注:调用过程中,可以使用clearTimeout(id_of_settimeout)终止
window.setTimeout或setTimeout,两个写法基本一样,只不过window.setTimeout将setTimeout函数作为全局window对象的一个属性来引用
setTimeout(functiontimeout(){console.log(Math.floor(Math.random()*100+1)); },500)
window.setTimeout方法调用函数有两种方法:
functionhello(){console.log("hello"); }window.setTimeout(hello,500);//不可以有参数window.setTimeout("hello()",500);//可以有参数
无论window.setTimeout还是window.setInterval,在使用函数名作为调用句柄时都不能带参数,而在许多场合必须要带参数,这就需要想方法解决。例如对于函数hello(_name),它用于针对用户名显示欢迎信息: var userName="jack";
functionhello(_name){ alert("hello,"+_name);//根据用户名显示欢迎信息}
这时,如果企图使用以下语句来使hello函数延迟3秒执行是不可行的:
window.setTimeout(hello(userName),3000);
这将使hello函数立即执行,并将返回值作为调用句柄传递给setTimeout函数,其结果并不是程序需要的。而使用字符串形式可以达到想要的结果:
window.setTimeout("hello(userName)",3000);
如果在延时期限到达之前取消演示执行,可以使用window.clearTimeout(timeoutId)方法
functionhello(){ alert("hello");}varid=window.setTimeout(hello,5000);document.onclick=function(){window.clearTimeout(id);}
这样,如果要取消显示,只需单击页面任何一部分,就执行了window.clearTimeout方法,使得超时操作被取消
除了前两个参数,setTimeout还允许添加更多的参数。它们将被传入推迟执行的函数
setTimeout(function(a,b){ console.log(a+b);},1000,1,2); //3
上面代码中,setTimeout共有4个参数。最后两个参数,将在1000毫秒之后回调函数执行时,作为回调函数的参数。
IE 9.0以下版本,只允许setTimeout有两个参数。这时有三种解决方法,第一种是自定义setTimeout,使用apply方法将参数输入回调函数;第二种是在一个匿名函数里面,让回调函数带参数运行,再把匿名函数输入setTimeout;第三种使用bind方法,把多余的参数绑定在回调函数上面,生成一个新的函数输入setTimeout
除了参数问题,setTimeout还有一个需要注意的地方:被setTimeout推迟执行的回调函数是在全局环境执行,这有可能不同于函数定义时的上下文环境
varx =1;varo = {x:2,y:function(){console.log(this.x); }};setTimeout(o.y,1000);//1
上面代码输出的是1,而不是2,这表示回调函数的运行环境已经变成了全局环境
再看一个不容易发现错误的例子
functionUser(login){this.login = login;this.sayHi =function(){console.log(this.login); }}varuser =newUser('John');setTimeout(user.sayHi,1000);//undefined
上面代码只会显示undefined,因为等到user.sayHi执行时,它是在全局对象中执行,所以this.login取不到值。为了防止出现这个问题,一种解决方法是将user.sayHi放在函数中执行
setTimeout(function(){ user.sayHi();},1000);//John
user.sayHi是在函数作用域内执行,而不是在全局作用域内执行,所以能够显示正确的值
另一种更通用的解决方法,则是采用闭包,将this与当前运行环境绑定