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。