如何用javascript設定延時執行

來源:互聯網
上載者:User

一、什麼叫做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的代碼,只需要直接調用就可以了,很方便 

   。也節省了代碼的量。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.