在JavaScript中,我们可以在设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行,JavaScript中计时器中主要使用window.setInterval()方法和window.setTimeout()方法。
计时器类型
一次性计时器:仅在指定的延迟时间之后触发一次。
间隔性触发计时器:每隔一定的时间间隔就触发一次。
setInterval()
在执行时,从载入页面后每隔指定的时间执行代码。

语法

setInterval(代码, 交互时间);
setInterval(函数, 交互时间, 参数1, 参数2, ...)

参数

  1. 代码:必须,要调用的函数或要执行的代码串
  2. 交互时间:必须,周期性执行或调用表达式之间的时间间隔,以毫秒计(1s=1000ms)
  3. 参数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)

参数

  1. 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(代码,延迟时间);

参数

  1. 要调用的函数或要执行的代码串。
  2. 延时时间:在执行代码前需等待的时间,以毫秒为单位(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)

参数

  1. 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>