window.setTimeout(expression,milliseconds); window.setInterval(expression,milliseconds);其中,expression可以是用引号括起来的一段代码,也可以是一个函数名,到了指定的时间,系统便会自动调用该函数,当使用函数名作为调用句柄时, 不能带有任何参数;而使用字符串时,则可以在其中写入要传递的参数。两个方法的第二个参数是milliseconds,表示延时或者重复执行的毫秒数。下 面分别介绍两种方法。
function hello(){alert("hello"); } window.setTimeout(hello,5000); 这段代码将使得页面打开5秒钟后显示对话框“hello”。其中最后一句也可以写为:window.setTimeout("hello()",5000);读者可以体会它们的差别,在window.setInterval方法中也有这样的性质。
function hello(){alert("hello"); } var id=window.setTimeout(hello,5000); document.onclick=function(){window.clearTimeout(id); } 这样,如果要取消显示,只需单击页面任何一部分,就执行了window.clearTimeout方法,使得超时操作被取消。//定义一个反复执行的调用 var id=window.setInterval("somefunction",10000); //取消定时执行 window.clearInterval(id);3. 挑战
var userName="jack"; //根据用户名显示欢迎信息 function hello(_name){alert("hello,"+_name); } 这时,如果企图使用以下语句来使hello函数延迟3秒执行是不可行的:window.setTimeout(hello(userName),3000);这将使hello函数立即执行,并将返回值作为调用句柄传递给setTimeout函数,其结果并不是程序需要的。而使用字符串形式可以达到想要的结果:
window.setTimeout("hello(userName)",3000);这里的字符串是一段JavaScript代码,其中的userName表示的是变量。但这种写法不够直观,而且有些场合必须使用函数名,下面用一个小技巧来实现带参数函数的调用:
var userName="jack"; //根据用户名显示欢迎信息 function hello(_name){alert("hello,"+_name); } //创建一个函数,用于返回一个无参数函数 function _hello(_name){return function(){hello(_name);} } window.setTimeout(_hello(userName),3000); </script> 这里定义了一个函数_hello,用于接收一个参数,并返回一个不带参数的函数,在这个函数内部使用了外部函数的参数,从而对其调用,不需要使用参数。在 window.setTimeout函数中,使用_hello(userName)来返回一个不带参数的函数句柄,从而实现了参数传递的功能。function display(){ alert(hello);}setTimeout("display()", 3000);alert("你首先看到的是我!")代码先输出哪个?答案在程序中很明显。为什么呢?
除了javascript执行进程外,还有一个需要在进程下一次空闲时间执行的代码队列,随着页面在其生命周期内的推移,代码会按照执行顺序添加到对列中,例如:当一个按钮被按下时,它的事件处理就会添加到队列中,并在下一个可能的时间内执行。
定时器对队列的工作方式是,当特定的时间过去后,将代码插入,注意添加到队列并不意味着它会马上执行,而只能说它会尽快执行,设定一个250ms后执行的定时器,不代表250ms后它会马上执行,它只会表示在250ms后被加入到队列中,如果这个时间点队列是空闲的,那么这段代码就会被执行。
请看以下代码:
var btn = document.getElementById("mybtn"); btn.onclick = function () { setTimeout(function () { document.getElementById("message").nodeName = "mymessage"; //其它代码 }, 250); }对于定时器最要注意的是:指定的时间间隔表示何时将定时器的代码添加到队列中,而不是何时执行代码。关于这个onclick事伯处理的进程时间线请看下图:
以上就是本文的全部内容,希望通过这篇文章大家更加了解javascript的定时器,大家共同进步。