setTimeout() 和 setInterval()

window对象有两个主要的定时方法,分别是setTimeout() 和 setInteval() 他们的语法基本上相同,但是完成的功能取有区别.
setTimeout()方法是定时程序,也就是在什么时间以后干什么。干完了就拉倒。可以用该方法设置暂停。该方法接受两个参数,要执行的代码和在执行它之前要等待的毫秒数(1/1000秒)。第一个参数可以是代码串(与eval()函数的参数相同),也可以是函数指针。例如,下面的代码都在1秒钟后显示一条警告:
setTimeout("alert('Hello World!')",1000);
setTimeout(function(){ alert('Hello World!'); },1000);
当然,还可以引用以前定义的函数:
function sayHelloWorld(){
alert("Hello World!");
}
setTimeout(sayHelloWorld,1000);
调用setTimeout()时,它创建一个数字暂停ID,与操作系统中的进程ID相似。暂停ID本质上是要延迟的进程ID,再调用 setTimeout()后,就不应该再执行它的代码。要取消还未执行的暂停,可调用clearTimeout()方法,并将暂停ID传递给它:
var iTimeoutId = setTimeout("alert('Hello World!')",1000);
alert(iTimeoutId);
clearTimeout(iTimeoutId);
其中,iTimeoutId 是一串数字,例如 38734218

“为什么要定义暂停,又在执行它之前将其取消呢?”请考虑在大多数应用程序中可见的工具提示。当把鼠标移动到一个按钮上时,停留一会,等待出现黄色的文本框,提示该按钮的功能。如果只是短暂的把鼠标该按钮上,然后很快将其移动到另一个按钮上,那么第一个按钮的工具提示就不会显示,这就是要在执行暂停代码前取消它的原因。因为你在执行代码前只想等待指定的时间量。如果用户的操作产生了不同的结果,则要取消该暂停。

setInterval()方法则是表示间隔一定时间反复执行某操作。时间间隔与暂停的运行方式相似,只是它无限此地每隔指定的时间段就重复执行一次指定的代码。可调用setInterval()方法设置时间间隔,它的参数与setTimeout()相同,是要执行的代码和每次执行之间等待的毫秒数。例如:
setInterval("alert('Hello world!')",1000);
setInterval(function() { alert("Hello world!"); },1000);

function sayHelloWorld(){
alert("Hello World!");
}
setInterval(sayHelloWorld,1000);
此外,与setTimeout()类似,setInterval()方法也创建时间间隔ID,以标识要执行的代码。clearInterval()方法可用这个ID阻止再次执行该代码。显然。这一点在使用时间间隔时更重要,因为如果不取消时间间隔,就会一直执行它,直到页面被卸载为止。下面是时间间隔用法的一个常见示例:
var iNum = 0;
var iMax = 100;
var iIntervalId = null;
function incNum(){
iNum++;
if(iNum == iMax){
clearInterval(iIntervalId);
}
}
iIntervalId = setInterval(incNum, 500);
在这段代码中,每隔500毫秒就对数字iNum进行一次增量运算,直到它达到最大值(iMax), 此时该时间间隔将被清除。也可以用暂停实现该操作,这样即不必跟踪时间间隔的ID,代码如下:
var iNum = 0;
var iMax = 100;
function incNum(){
iNum++;
if(iNum != iMax){
setTimeout(incNum,500);
}
}
setTimeout(incNum,500);
这段代码使用链接暂停,即setTimeout()执行的代码页调用了setTimeout()。如果在执行过增量运算后,iNum不等于 iMax,就调用setTimeout()方法。不必跟踪暂停ID,也不必清除它,因为代码执行后,将销毁暂停ID。

如果用setTimeout实现setInerval的功能,就需要在执行的程序中再定时调用自己才行(setTimeout( ) 预设只是执行一次,但我们可以使用一个循环方式,使到一个setTimeout( ) 再启动自己一次, 就会使到第二個 setTimeout( ) 执行, 第二个又启动第三个, 这样循环下去, 这 setTimeout( ) 就会不断执行)。如果要清除计数器需要根据使用的方法不同,调用不同的清除方法:
var timeID = null;
//timeout方法
timeID=setTimeout('northsnow()',1000);
clearTimeout(timeID);
//interval方法
timeID=setInterval('northsnow()',1000);
clearInteval(timeID);
<script type="text/javascript">
var count = 0;
var timeID = null;
function counter() {
count++;
$("#count").html(count + '%');
timeID = setTimeout("counter()", 1000);//注意:执行的函数需要加引号,否则会报错的
if (count > 10) {
clearTimeout(timeID); //注意:clearTimeout(timeID)必须位于setTimeout()之后,不能是之前,原因很容易呦!
}
}
$(function() {
counter();
});
</script>

<script type="text/javascript">
var count = 0;
var timeID = null;
function counter() {
count++;
$("#count").html(count + '%');
if (count > 10) {
clearInterval(timeID);
}
}
$(function() {
timeID = setInterval('counter()', 1000); //注意:执行的函数需要加引号,否则会报错的

});
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值