js中setInterval與setTimeout的用法和區別

setTimeout

  定義和用法:  setTimeout()方法用於在指定的毫秒數後調用函數或計算表達式。  javascript

   語法:   setTimeout(code,millisec)   html

   參數:   java

   code (必需):要調用的函數後要執行的 JavaScript 代碼串。   app

   millisec(必需):在執行代碼前需等待的毫秒數。  函數

   提示:   setTimeout() 只執行 code 一次。若是要屢次調用,請使用 setInterval() 或者讓 code 自身再次調用 setTimeout()。測試

 

兩種調用函數的寫法:ui

function page_list(){spa

  alert("shihuan");.net

}prototype

window.setTimeout(page_list, 5000);  //表示延時5秒執行page_list()函數
window.setTimeout("page_list()", 30000);  //表示延時30秒執行page_list()函數

 

帶參數方法使用setTimeout要注意,setTimeout("函數名("+參數+")",毫秒數),這裏的參數只能是字符串形式的,而不能傳遞一個對象,網上不少朋友也在問此類問題,我在此說明下,如下我舉幾個個簡單的例子:  網上查找下「帶參數 setTimeout」,不少朋友寫了不少方法來實現使用setTimeout帶對象的方法循環,例如: <script language="javascript">   

  var __sto = setTimeout;   

  window.setTimeout = function(callback, timeout, param) {      

       var args = Array.prototype.slice.call(arguments, 2);      

       var _cb = function() {                      

                      callback.apply(null, args);                

                 }     __sto(_cb, timeout);   }   

       //測試代碼   

       function shihuan(a) {     

           alert(a);   

       }   

       function yushibo(a, b, c) {     

            alert(a+ b + c);   

       }   

       var a = new Object();   

       window.setTimeout(shihuan, 1000,a);   

       window.setTimeout(yushibo, 2000,a, 6,7);

</script>

 

此例中,setTimeout用法,setTimeout(回調函數, 時間, 參數1, ..., 參數n)。

 

--------------------------------------------------------------------------------------------------

 

setInterval定義和用法

setInterval() 方法可按照指定的週期(以毫秒計)來調用函數或計算表達式。

setInterval() 方法會不停地調用函數,直到 clearInterval() 被調用或窗口被關閉。由 setInterval() 返回的 ID 值可用做 clearInterval() 方法的參數。

語法

setInterval(code,millisec[,"lang"])
參數 描述
code 必需。要調用的函數或要執行的代碼串。
millisec 必須。週期性執行或調用 code 之間的時間間隔,以毫秒計。

返回值

一個能夠傳遞給 Window.clearInterval() 從而取消對 code 的週期性執行的值。

 

例子:

<html>
<body>

<form>
   <input type="text" id="clock" size="35" />
   <script language=javascript>
      var int=self.setInterval("clock()", 50)
      function clock(){
          var t=new Date()
          document.getElementByIdx_x_xx_x_x_x_x_x("clock").value = t
      }
   </script>
</form>
<button onclick="int=window.clearInterval(int)">Stop interval</button>
</body>
</html>

 

--------------------------------------------------------------------------------------------------

clearTimeout()和clearInterval() :

JS裏設定延時:
使用SetInterval和設定延時函數setTimeout 很相似。
setTimeout 運用在延遲一段時間,再進行某項操做。
setTimeout("function",time) 設置一個超時對象
setInterval("function",time) //設置一個超時對象

SetInterval爲自動重複,setTimeout不會重複。
clearTimeout(對象) 清除已設置的setTimeout對象
clearInterval(對象) 清除已設置的setInterval對象
1、什麼叫作JavaScript 的計時事件
使用JavaScript能夠實現代碼的延時執行,也就是說當一個函數被調用時不當即執行某些代碼,而是等一段指定的時間後再執行,這就叫作計時事件。
2、JavaScript 的計時事件的函數

setTimeout() //- 在指定時間後執行代碼
clearTimeout() //- 取消 setTimeout()

注意: setTimeout() 和 clearTimeout() 都是HTML DOM 的 Window 對象的函數。
3、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)
4、clearTimeout詳解
語法:clearTimeout(setTimout的變量名)
示例:clearTimeout(t)  //其中t爲前面設置的setTimeout的變量
使用clearTimeout能夠隨時中止計時。
5、應用技巧
建議將setTimeout單獨設置爲一個函數。如:

function delayRun(code, time) {
  var t = setTimeout(code, time);
}

這樣,在須要讓某段代碼延時執行的時候,只需在這段代碼前加入這個函數就能夠了。如:
onmouseover = delayRun("setTab(0,0)", 500)
其中setTab是一個自定義的函數。若是之後不想讓setTab延時執行,則去掉語句中的delayRun相關的代碼便可,
改成:onmouseover=setTab(0, 0) 就能夠了。
這種寫法避免每個須要延時的地方都寫一段setTimeout的代碼,只須要直接調用就能夠了,很方便。也節省了代碼的量。


無節操廣告,歡迎關注: 點我

相關文章
相關標籤/搜索