更新時(shí)間:2021-11-16 來源:黑馬程序員 瀏覽量:
在瀏覽網(wǎng)頁的過程中,我們經(jīng)??梢钥吹捷啿D效果,即每隔一段時(shí)間,圖片就會(huì)自動(dòng)切換一次;或者在商品頁面看到商品倒計(jì)時(shí)功能,這些動(dòng)畫就用到了定時(shí)器。定時(shí)器就是在指定時(shí)間后執(zhí)行特定操作,或者讓程序代碼每隔一段時(shí)間執(zhí)行一次,實(shí)現(xiàn)間歇操作。
在JavaScript中,提供了兩組方法用于定時(shí)器的實(shí)現(xiàn),具體方法如表8-1所示。
表8-1定時(shí)器方法
表8-1中,setTimeout0和setlnterval0方法都可以在一個(gè)固定時(shí)間段內(nèi)執(zhí)行代碼,不同的是前者只執(zhí)行一次代碼,而后者會(huì)在指定的時(shí)間后自動(dòng)重復(fù)執(zhí)行代碼。
在實(shí)際開發(fā)中,我們可以通過setTimeout0方法實(shí)現(xiàn)函數(shù)的一次調(diào)用,并且可以通過clearTimeout0來清除setTimeout()定時(shí)器。
setTimeout()和setInterval()的語法格式如下。
setTimeout(調(diào)用的函數(shù),[延遲的毫秒數(shù)]) setInterval(調(diào)用的函數(shù),[延遲的毫秒數(shù)])
在上述語法中,第1個(gè)參數(shù)表示到達(dá)第2個(gè)參數(shù)設(shè)置的等待時(shí)間后要執(zhí)行的代碼,也可以傳入一個(gè)函數(shù),或者函數(shù)名,第2個(gè)參數(shù)的時(shí)間單位以毫秒(ms)計(jì)。
下面我們以setTimeout()為例進(jìn)行代碼演示,具體代碼如下。
//參數(shù)形式1:用字符串表示一段代碼 setTimeout('alert ("JavaScript");', 3000); //參數(shù)形式2:傳人一個(gè)匿名函數(shù) setTimeout (function () { alert ('JavaScript'); },3000); //參數(shù)形式3:傳入函數(shù)名 setTimeout(fn, 3000); function fn(){ console.log('JavaScript'); }
在上述代碼中,當(dāng)參數(shù)為一個(gè)函數(shù)名時(shí),這個(gè)函數(shù)名不需要加()小括號(hào),否則就變成了立即執(zhí)行這個(gè)函數(shù),將函數(shù)執(zhí)行后的返回值傳入。如果延遲的毫秒數(shù)省略時(shí),默認(rèn)為0。
在實(shí)際開發(fā)中,考慮到一個(gè)網(wǎng)頁中可能會(huì)有很多個(gè)定時(shí)器,所以建議用一個(gè)變量保存定時(shí)器的id(唯一標(biāo)識(shí)),若想要在定時(shí)器啟動(dòng)后,取消該定時(shí)器操作,可以將setTimeost()的返回值(定時(shí)器id)傳遞給clearTimeout)方法。示例代碼如下。
//在設(shè)置定時(shí)器時(shí),保存定時(shí)器的唯一標(biāo)識(shí) var timer = setTimeout (fn, 3000): //如果要取消定時(shí)器,可將唯一標(biāo)識(shí)的傳遞給clearTimeout ()方法 clearTimeout(timer);
【案例】3秒后自動(dòng)關(guān)閉廣告
本案例將會(huì)使用sefTimeoat()實(shí)現(xiàn)3秒后自動(dòng)關(guān)閉廣告的效果,具體代碼如下。
<body> <saript> conaole.log('廣告是示') var timer = setTimeout(fn, 3000): function fn(){ console.log('廣告關(guān)閉了'); } </script> </body>
上述代碼中,第4行代碼定義了一個(gè)timer 變量用于保存setTimeout定時(shí)器的功能為3000ms后執(zhí)行fn函數(shù)。第5-7行代碼定義處理函數(shù)fn,并“打印廣告關(guān)閉了”。
JavaScript面向?qū)ο笮薷臉?biāo)簽頁詳解
JavaScript中怎樣創(chuàng)建Date對(duì)象?