1.什麼是定時器javascript
2.setInterval、clearInterval、setTimeout的使用html
JavaScript 是單線程語言,但它容許經過設置超時值和間歇時間值來調度代碼在特定的時刻執行。
1.setIntervaljava
setInterval() 方法可按照指定的週期(以毫秒計)來調用函數或計算表達式。
setInterval() 方法會不停地調用函數,直到 clearInterval() 被調用或窗口被關閉。由 setInterval() 返回的 ID 值可用做
語法:數組
setInterval(function, milliseconds)複製代碼
code/function必需。要調用一個代碼串,也能夠是一個函數。bash
milliseconds必須。週期性執行或調用 code/function 之間的時間間隔,以毫秒計。markdown
代碼:每隔1000毫秒執行console.log(1)函數
<!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript"> setInterval(function(){ console.log(1) },1000) </script> </body> </html>複製代碼
2.setTimeoutoop
setTimeout() 方法用於在指定的毫秒數後調用函數或計算表達式。
語法:ui
setTimeout(function, milliseconds)複製代碼
代碼:延遲執行,打開頁面隔1000毫秒執行console.log(1)spa
<!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript"> setTimeout(function(){ console.log(1) },1000) </script> </body> </html>複製代碼
這裏能夠看出來setInterval和setTimeout的區別了,setInterval是一直打印,setTimeout只是執行了一次
3.clearInterval
clearInterval() 方法可取消由 setInterval() 設置的 timeout。
clearInterval() 方法的參數必須是由 setInterval() 返回的 ID 值。
語法:
clearInterval(id_of_setinterval):id_of_setinterval 由 setInterval() 返回的 ID 值。
代碼:面這個例子將每隔 50 毫秒調用 clock() 函數。您也能夠使用一個按鈕來中止這個 clock:
<html> <body> <input type="text" id="clock" size="35" /> <script language=javascript> var int=self.setInterval("clock()",50) function clock() { var t=new Date() document.getElementById("clock").value=t } </script> </form> <button onclick="int=window.clearInterval(int)"> Stop interval</button> </body> </html>複製代碼