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.getElementById("+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的代碼,只需要直接調用就可以了,很方便。也節省了代碼的量。