在JavaScript中,我们可以在设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行,JavaScript中计时器中主要使用window.setInterval()方法和window.setTimeout()方法。
计时器类型
一次性计时器:仅在指定的延迟时间之后触发一次。
间隔性触发计时器:每隔一定的时间间隔就触发一次。
setInterval()
在执行时,从载入页面后每隔指定的时间执行代码。
语法
setInterval(代码, 交互时间);
setInterval(函数, 交互时间, 参数1, 参数2, ...)
参数
- 代码:必须,要调用的函数或要执行的代码串
- 交互时间:必须,周期性执行或调用表达式之间的时间间隔,以毫秒计(1s=1000ms)
- 参数1,参数2:可选,传给执行函数的其他参数(IE9 及其更早版本不支持该参数)。
返回值:一个可以传递给 clearInterval() 从而取消对”代码”的周期性执行的值。
实例
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>定时器</title>
<script type="text/javascript">
var int = window.setInterval(clock, 1000);
var attime;
function clock() {
var time = new Date();
attime = time.getHours() + ':' + time.getMinutes() + ':' + time.getSeconds();
document.getElementById("clock").value = attime;
}
</script>
</head>
<body>
<form>
<input type="text" id="clock" size="50" />
</form>
</body>
</html>
clearInterval()
clearInterval() 方法可取消由 setInterval() 设置的交互时间。
语法
clearInterval(id_of_setInterval)
参数
- id_of_setInterval:由 setInterval() 返回的 ID 值。
实例
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>计时器</title>
<script type="text/javascript">
function clock(){
var time=new Date();
document.getElementById("clock").value = time;
}
var d = setInterval(clock, 1000);
</script>
</head>
<body>
<form>
<input type="text" id="clock" size="50" />
<input type="button" value="Stop" onclick="clearInterval(d)" />
</form>
</body>
</html>
setTimeout()
setTimeout()计时器,在载入后延迟指定时间后,去执行一次表达式,仅执行一次。
语法
setTimeout(代码,延迟时间);
参数
- 要调用的函数或要执行的代码串。
- 延时时间:在执行代码前需等待的时间,以毫秒为单位(1s=1000ms)。
实例
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>计时器</title>
<script type="text/javascript">
var num = 0;
function startCount() {
document.getElementById('count').value = num;
num = num + 1;
setTimeout("startCount()", 1000);
}
</script>
</head>
<body>
<form>
<input type="text" id="count" />
<input type="button" onclick="startCount()" value="开始" />
</form>
</body>
</html>
clearTimeout()
setTimeout()和clearTimeout()一起使用,停止计时器。
语法:
clearTimeout(id_of_setTimeout)
参数
- id_of_setTimeout:由 setTimeout() 返回的 ID 值。该值标识要取消的延迟执行代码块。
实例
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>计时器</title>
<script type="text/javascript">
var num = 0;
var i;
function startCount() {
document.getElementById('count').value = num;
num = num + 1;
i = setTimeout("startCount()", 1000);
}
function stopCount() {
clearTimeout(i);
}
</script>
</head>
<body>
<form>
<input type="text" id="count" />
<input type="button" value="Start" onclick="startCount()" />
<input type="button" value="Stop" onclick="stopCount()" />
</form>
</body>
</html>
发表评论