首頁 >web前端 >js教程 >JavaScript定時器詳解及實例_javascript技巧

JavaScript定時器詳解及實例_javascript技巧

WBOY
WBOY原創
2016-05-16 17:27:311141瀏覽

JS裡設定延遲:
使用SetInterval和設定延時函數setTimeout 很類似。 setTimeout 運用在延遲一段時間,再進行某項操作。
setTimeout("function",time) 設定一個逾時物件
setInterval("function",time) 設定一個逾時物件
SetInterval為自動重複,setTimeout不會重複。
clearTimeout(物件) 清除已設定的setTimeout物件
clearInterval(物件) 清除已設定的setInterval物件
使用計時器實作JavaScript的延期執行或重複執行
window物件提供了兩個方法來達到定時器的效果,分別是window.setTimeout()和window.setInterval。其中前者可以使一段程式碼在指定時間後運作;而後者則可以讓一段程式碼每過指定時間就執行一次。它們的原型如下:
window.setTimeout(expression,milliseconds);
window.setInterval(expression,milliseconds);
其中,expression可以是用引號括起來的一段程式碼,也可以是一個函數名,到了指定的時間,系統便會自動呼叫該函數,當使用函數名作為呼叫句柄時, 不能帶有任何參數;而使用字串時,則可以在其中寫入要傳遞的參數。兩個方法的第二個參數是milliseconds,表示延時或重複執行的毫秒數。下 面分別介紹兩種方法。
1. window.setTimeout方法
此方法可以延時執行一個函數,例如:

複製程式碼 程式碼如下:



這段程式碼將讓頁面開啟5秒鐘後顯示對話框「hello」。其中最後一句也可以寫成:
複製程式碼 程式碼如下:

window.setTimeout( "hello()",5000);

讀者可以體會它們的差別,在window.setInterval方法中也有這樣的性質。
如果在延遲期限到達之前取消延執行,可以使用window.clearTimeout(timeoutId)方法,該方法接收一個id,表示一個定時器。這個id是由setTimeout方法回傳的,例如:
複製程式碼 程式碼如下:


程式碼如下:






}
//--> >這樣,如果要取消顯示,只需按一下頁面任何一部分,就執行了window.clearTimeout方法,使得逾時操作被取消。 2. window.setInterval方法 這個方法使得一個函數每隔固定時間被呼叫一次,是一個很常用的方法。如果想要取消定時執行,和clearTimeout方法類似,可以呼叫 window.clearInterval方法。 clearInterval方法同樣接收一個setInterval方法回傳的值作為參數。例如:



複製程式碼

程式碼如下:

//定義一個重複執行的呼叫//定義一個重複執行的呼叫var id=window.setInterval("somefunction",10000); //取消定時執行window.clearInterval(id);
上面的程式碼僅用來說明怎樣取消一個定時執行。實際上在許多場合都需要用到setInterval方法,下面將設計一個秒錶,來介紹setInterval 函數的用途:該秒錶將包含兩個按鈕和一個用於顯示時間的文字方塊。當點選開始按鈕時開始計時,最小單位為0.01秒,此時再次點選按鈕則停止計時,文字方塊顯示 示經過的時間。另外一個按鈕用於將當前時間清零。其實作程式碼如下: 複製程式碼 程式碼如下:




New Document












7.4.3 給定時器呼叫傳遞參數
無論是window.setTimeout或window.setInterval,在使用函數名稱作為呼叫句柄時都不能帶參數,而在許多場合必須要帶參數,這就需要想方法解決。例如函數hello(_name),它用於針對使用者名稱顯示歡迎訊息:




複製程式碼

程式碼如下:

var userName="jack"; //依照使用者名稱顯示歡迎訊息function hello(_name){       alert("hello," _name); } } }
}
}
}
}
}
}
}
}
}
}
} 複製代碼


程式碼如下:


window.setTimeout(hello(userName),3000); 複製程式碼


程式碼如下:


window.setTimeout("hello(userName)",3000); 複製程式碼 程式碼如下:

  setTimeout方法是定時程序,也就是在什麼時間以後做什麼。乾完了就拉倒。
  setInterval方法則是表示間隔一定時間重複執行某操作。
  JS裡設定延時:
使用SetInterval和設定延時函數setTimeout 很類似。 setTimeout 運用在延遲一段時間,再進行某項操作。
setTimeout("function",time) 設定一個逾時物件
setInterval("function",time) 設定一個逾時物件
SetInterval為自動重複,setTimeout不會重複。
clearTimeout(物件) 清除已設定的setTimeout物件
clearInterval(物件) 清除已設定的setInterval物件
        若使用setTimeout實作setInerval的功能,就需要在執行的程式行中再設定時呼叫自己才已設定好設定自己。如果要清除計數器需要依照使用的方法不同,請呼叫不同的清除方法:
例如:



複製程式碼 程式碼如下:tttt=setTimeout('northsnow()',1000);
clearTimeout(tttt);


或:


或: 或:



複製程式碼

舉個例子:




複製程式碼


程式碼如下:



   {
      window.clearTimeout(timer2);
  >
複製程式碼 程式碼如下:






陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn