標籤:c style class blog code java
setTimeout
定義和用法: setTimeout()方法用於在指定的毫秒數後調用函數或計算運算式。
文法: setTimeout(code,millisec)
參數: code (必需):要調用的函數後要執行的 JavaScript 代碼串。 millisec(必需):在執行代碼前需等待的毫秒數。
提示: setTimeout() 只執行 code 一次。如果要多次調用,請使用 setInterval() 或者讓 code 自身再次調用 setTimeout()。 兩種調用函數的寫法:
1 function page_list(){2 alert("shihuan");3 }4 window.setTimeout(page_list, 5000); //表示延時5秒執行page_list()函數5 window.setTimeout("page_list()", 30000); //表示延時30秒執行page_list()函數
帶參數方法使用setTimeout要注意,setTimeout("函數名("+參數+")",毫秒數),這裡的參數只能是字串形式的,而不能傳遞一個對象,網上很多朋友也在問此類問題,我在此說明下,以下舉幾個個簡單的例子:網上尋找下“帶參數 setTimeout”,很多朋友寫了很多方法來實現使用setTimeout帶對象的方法迴圈,例如:
1 <script language="javascript"> 2 var __sto = setTimeout; 3 window.setTimeout = function(callback, timeout, param) { 4 var args = Array.prototype.slice.call(arguments, 2); 5 var _cb = function() { 6 callback.apply(null, args); 7 } __sto(_cb, timeout); } 8 //測試代碼 9 function shihuan(a) { 10 alert(a); 11 } 12 function yushibo(a, b, c) { 13 alert(a + b + c); 14 } 15 var a = new Object(); 16 window.setTimeout(shihuan, 1000, a); 17 window.setTimeout(yushibo, 2000, a, 6, 7);18 </script>
此例中,setTimeout用法,setTimeout(回呼函數, 時間, 參數1, ..., 參數n)。
setInterval定義和用法
setInterval() 方法可按照指定的周期(以毫秒計)來調用函數或計算運算式。
setInterval() 方法會不停地調用函數,直到 clearInterval() 被調用或視窗被關閉。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的參數。
文法
setInterval(code,millisec[,"lang"])
| 參數 |
描述 |
| code |
必需。要調用的函數或要執行的代碼串。 |
| millisec |
必須。周期性執行或調用 code 之間的時間間隔,以毫秒計。 |
傳回值
一個可以傳遞給 Window.clearInterval() 從而取消對 code 的周期性執行的值。
1 <html> 2 <body> 3 <form> 4 <input type="text" id="clock" size="35" /> 5 <script language=javascript> 6 var int=self.setInterval("clock()", 50) 7 function clock(){ 8 var t=new Date() 9 document.getElementByIdx_x_xx_x_x_x_x_x("clock").value = t10 }11 </script>12 </form>13 <button onclick="int=window.clearInterval(int)">Stop interval</button>14 </body>15 </html>
clearTimeout()和clearInterval() :
JS裡設定延時:
使用SetInterval和設定延時函數setTimeout 很類似。
setTimeout 運用在延遲一段時間,再進行某項操作。
setTimeout("function",time) 設定一個逾時對象
setInterval("function",time) //設定一個逾時對象
SetInterval為自動重複,setTimeout不會重複。
clearTimeout(對象) 清除已設定的setTimeout對象
clearInterval(對象) 清除已設定的setInterval對象
一、什麼叫做JavaScript 的計時事件
使用JavaScript可以實現代碼的延時執行,也就是說當一個函數被調用時不立即執行某些代碼,而是等一段指定的時間後再執行,這就叫做計時事件。
二、JavaScript 的計時事件的函數
setTimeout() //- 在指定時間後執行代碼
clearTimeout() //- 取消 setTimeout()
注意: setTimeout() 和 clearTimeout() 都是HTML DOM 的 Window 對象的函數。
三、setTimeout詳解
var t = setTimeout("javascript 語句", 時間參數)
註:時間參數單位為毫秒
樣本:var t=setTimeout("alert(‘3 seconds!‘)", 3000)
如果js語句帶變數,則必須用+號將變數串連起來,如:
var t = setTimeout("document.getElementByIdx_x_xx_x_x_x_x_x("+menuid+").style.display=‘none‘", 3000)
四、clearTimeout詳解
文法:clearTimeout(setTimeout的變數名)
樣本:clearTimeout(t) //其中t為前面設定的setTimeout的變數
使用clearTimeout可以隨時停止計時。
五、應用技巧
建議將setTimeout單獨設定為一個函數。如:
function delayRun(code, time) {
var t = setTimeout(code, time);
}
這樣,在需要讓某段代碼延時執行的時候,只需在這段代碼前加入這個函數就可以了。如:
onmouseover = delayRun("setTab(0,0)", 500)
其中setTab是一個自訂的函數。如果以後不想讓setTab延時執行,則去掉語句中的delayRun相關的代碼即可,
改為:onmouseover=setTab(0, 0) 就可以了。
這種寫法避免每一個需要延時的地方都寫一段setTimeout的代碼,只需要直接調用就可以了,很方便。也節省了代碼的量。