setInterval() 定義和用法
setInterval() 方法可按照指定的周期(以毫秒計)來執行函數或表達式。該方法會不停地循環調用函數,直到使用 clearInterval() 明確停止該函數或窗口被關閉。clearInterval() 函數的參數即 setInterval() 返回的 ID 值。
語法
setInterval(code,millisec[,"lang"])
code 必需。要調用的函數或要執行的代碼串。
millisec 必須。周期性執行或調用 code 之間的時間間隔,以毫秒計。
返回值
一個可以傳遞給 Window.clearInterval() 從而取消對 code 的周期性執行的值。
使用示例:
復制代碼 代碼如下:
<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
<input type="text" id="clock" size="35" />
<script language=javascript>
var int=setInterval("clock()",50);
function clock(){
var t=new Date();
document.getElementById("clock").value=t;
}
</script>
</form>
<button onclick="window.clearInterval(int)">
停止 interval 事件</button>
</body>
</html>
setTimeout() 定義和用法
setTimeout() 方法用於在指定的毫秒數後調用函數或計算表達式,該方法與 setInterval() 方法不同的是該方法只執行一次。
語法
setTimeout(code,millisec)
code 必需。要調用的函數後要執行的 JavaScript 代碼串。
millisec 必需。在執行代碼前需等待的毫秒數,以毫秒計。
提示:
(1)setTimeout() 雖然是只執行一次代碼。但如果許要多次調用,除了使用 setInterval() 外還可以讓被執行的代碼裡面自身再次調用 setTimeout() 方法已達到多次執行的目的。
(2)另外setTimeout()方法也同樣可以返回一個ID值,以方便使用clearInterval()方法對使用setTimeout()方法的取消。
使用示例:
復制代碼 代碼如下:
<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<head>
<script type="text/javascript">
function timedMsg(){
var t=setTimeout("alert('3 秒時間到!')",3000);
}
function timedMsgAways(){
alert('3 秒時間到!');
var t=setTimeout("timedMsgAways()",3000);
}
</script>
</head>
<body>
<form>
<input type="button" value="3 秒後警告" onClick="timedMsg()"><br />
<input type="button" value="循環 3 秒警告" onClick="timedMsgAways()">
</form>
</body>
</html>
對於這兩個方法,需要注意的是如果要求在每隔一個固定的時間間隔後就精確地執行某動作,那麼最好使用setInterval,而如果不想由於連續調用產生互相干擾的問題,尤其是每次函數的調用需要繁重的計算以及很長的處理時間,那麼最好使用setTimeout。