js中setTimeout和setInterval性能详解总结 http://click.aliyun.com/m/24032/

摘要: 在写H5游戏时经常需要使用定时刷新页面实现动画效果,比较常用即setTimeout()以及setInterval() setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则是在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。

在写H5游戏时经常需要使用定时刷新页面实现动画效果,比较常用即setTimeout()以及setInterval()

setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则是在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。也就是说setTimeout()只执行一次,setInterval()可以执行多次。两个函数的参数也相同,第一个参数是要执行的code或句柄,第二个是延迟的毫秒数

setTimeout

描述

var timeoutID = window.setTimeout(code,millisec);
点击并拖拽以移动
timeoutID:定时器ID号,它可以在clearTimeout()函数中被用来清除定时器。
code:一个被执行的代码串或函数
millisec:延迟的时间,单位毫秒。如果没有指定,默认为0

setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式

注:调用过程中,可以使用clearTimeout(id_of_settimeout)终止

window.setTimeout或setTimeout,两个写法基本一样,只不过window.setTimeout将setTimeout函数作为全局window对象的一个属性来引用

setTimeout(function timeout(){ console.log(Math.floor(Math.random()*100 + 1)); },500)
点击并拖拽以移动
window.setTimeout方法调用函数有两种方法:

function hello(){ console.log("hello"); } window.setTimeout(hello,500); //不可以有参数 window.setTimeout("hello()",500); //可以有参数
点击并拖拽以移动
无论window.setTimeout还是window.setInterval,在使用函数名作为调用句柄时都不能带参数,而在许多场合必须要带参数,这就需要想方法解决。例如对于函数hello(_name),它用于针对用户名显示欢迎信息: var userName="jack";

function hello(_name){ alert("hello,"+_name); //根据用户名显示欢迎信息 }
点击并拖拽以移动
这时,如果企图使用以下语句来使hello函数延迟3秒执行是不可行的:

window.setTimeout(hello(userName),3000);
点击并拖拽以移动
这将使hello函数立即执行,并将返回值作为调用句柄传递给setTimeout函数,其结果并不是程序需要的。而使用字符串形式可以达到想要的结果:

window.setTimeout("hello(userName)",3000);
点击并拖拽以移动
如果在延时期限到达之前取消演示执行,可以使用window.clearTimeout(timeoutId)方法

function hello(){ alert("hello"); } var id=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推迟执行的回调函数是在全局环境执行,这有可能不同于函数定义时的上下文环境

var x = 1; var o = { x: 2, y: function(){ console.log(this.x); } }; setTimeout(o.y,1000); //1
点击并拖拽以移动
上面代码输出的是1,而不是2,这表示回调函数的运行环境已经变成了全局环境

再看一个不容易发现错误的例子

function User(login) { this.login = login; this.sayHi = function() { console.log(this.login); } } var user = new User('John'); setTimeout(user.sayHi, 1000); //undefined

点击并拖拽以移动
上面代码只会显示undefined,因为等到user.sayHi执行时,它是在全局对象中执行,所以this.login取不到值。为了防止出现这个问题,一种解决方法是将user.sayHi放在函数中执行

http://click.aliyun.com/m/24032/

猜你喜欢

转载自3554661963.iteye.com/blog/2381424