在JavaScript中,我们可以在设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行。
计时器类型:
①一次性计时器:仅在指定的延迟时间之后触发一次。
②间隔性触发计时器:每隔一定的时间间隔就触发一次。
方法 描述
setTimeout() 指定的延迟时间之后来执行代码
clearTimeout() 取消setTimeout的设置
setInterval() 每隔指定的时间执行代码
clearInterval() 取消setInterval的设置
一次性计时器setTimeout()
setTimeout()计时器,在载入后延迟指定时间后,去执行一次表达式,仅执行一次。
语法:setTimeout(代码/方法,延迟时间);
参数说明:
1. 要调用的函数或要执行的代码串。
2. 延时时间:在执行代码前需等待的时间,以毫秒为单位(1s=1000ms)。
function sayHello()
{
var timer = setTimeout("alert('hello!')",3000);
}
取消计时器clearTimeout()
setTimeout()和clearTimeout()一起使用,停止计时器。
语法:clearTimeout(id_of_setTimeout)
参数说明:id_of_setTimeout:由 setTimeout() 返回的 ID 值。该值标识要取消的延迟执行代码块。v
ar num = 0, timeout;
function startCount()//开始计数
{
document.getElementById("count").value = num;
num++;
timeout = setTimeout(startCount,1000); //递归就是在该方法运行的过程中调用自己
}
function stopCount()//停止计数
{
clearTimeout(timeout);
}
间隔性定时器setInterval()
计时器setInterval():在执行时,从载入页面后每隔指定的时间执行代码。
语法:setInterval(代码/方法,交互时间);
参数说明:
1. 代码:要调用的函数或要执行的代码串。
2. 交互时间:周期性执行或调用表达式之间的时间间隔,以毫秒计(1s=1000ms)。
返回值:一个可以传递给 clearInterval() 从而取消对"代码"的周期性执行的值。
调用函数格式(假设有一个clock()函数)
setInterval("clock()",1000)或setInterval(clock,1000)
var intTime = setInterval(clock, 1000);
function clock()//每1秒出现一次嗨喽
{
var curTime = alert(“hello!”);
document.innerHTML = curTime;
}
取消计时器clearInterval()
clearInterval() 方法可取消由 setInterval() 设置的交互时间。
语法:clearInterval(id_of_setInterval)
参数说明:id_of_setInterval:由 setInterval() 返回的 ID 值。
每隔 100 毫秒调用 clock() 函数,并显示时间。当点击按钮时取消定时
var timerone, timertwo;
window.onload = function () {
timerone = setInterval("alert('hello!')", 2000);
timertwo = setTimeout("clearInterval(timerone);console.log('完成')", 3000); //3秒后停止循环
}