一、什么叫做JavaScript 的計(jì)時(shí)事件
使用JavaScript可以實(shí)現(xiàn)代碼的延時(shí)執(zhí)行,也就是說(shuō)當(dāng)一個(gè)函數(shù)被調(diào)用時(shí)不立即執(zhí)行某些代碼,而是
等一段指定的時(shí)間后再執(zhí)行,這就叫做計(jì)時(shí)事件。
二、JavaScript 的計(jì)時(shí)事件的函數(shù)
setTimeout() - 在指定時(shí)間后執(zhí)行代碼
clearTimeout() - 取消 setTimeout()
注意: setTimeout() 和 clearTimeout() 都是HTML DOM 的 Window 對(duì)象的函數(shù)。
三、setTimeout詳解
var t=setTimeout("javascript 語(yǔ)句",時(shí)間參數(shù))
注:時(shí)間參數(shù)單位為毫秒
示例:var t=setTimeout("alert('3 seconds!')",3000)
如果js語(yǔ)句帶變量,則必須用+號(hào)將變量連接起來(lái),如:
var t=setTimeout("document.getElementByIdx("+menuid+").style.display='none'",3000)
四、clearTimeout詳解
語(yǔ)法:clearTimeout(setTimeout的變量名)
示例:clearTimeout(t) //其中t為前面設(shè)置的setTimeout的變量
使用clearTimeout可以隨時(shí)停止計(jì)時(shí)。
五、應(yīng)用技巧
建議將setTimeout單獨(dú)設(shè)置為一個(gè)函數(shù)。如:
function delayRun(code,time) {
var t=setTimeout(code,time);
}
這樣,在需要讓某段代碼延時(shí)執(zhí)行的時(shí)候,只需在這段代碼前加入這個(gè)函數(shù)就可以了。如:
onmouseover=delayRun("setTab(0,0)",500)
其中setTab是一個(gè)自定義的函數(shù)。如果以后不想讓setTab延時(shí)執(zhí)行,則去掉語(yǔ)句中的delayRun相關(guān)的
代碼即可,改為:onmouseover=setTab(0,0) 就可以了。
這種寫法避免每一個(gè)需要延時(shí)的地方都寫一段setTimeout的代碼,只需要直接調(diào)用就可以了,很方便
。也節(jié)省了代碼的量。
該文章在 2011/11/12 14:55:36 編輯過(guò)