DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS定時器使用,定時定點,固定時刻,循環執行詳解
JS定時器使用,定時定點,固定時刻,循環執行詳解
編輯:關於JavaScript     

本文概述:本文主要介紹通過JS實現定時定點執行,在某一個固定時刻執行某個函數的方法。比如說在下一個整點執行,在每一個整點執行,每隔10分鐘定時執行的方法。

JavaScript中有兩個定時器方法:setTimeout()和setInterval()。

這兩個方法都可以用來實現在一個固定時間段之後去執行JavaScript。實際上,setTimeout和setInterval的語法相同。它們都有兩個參數,一個是將要執行的代碼字符串,或者函數名,還有一個是以毫秒為單位的時間間隔,當過了那個時間段之後就將執行那段代碼。

不過這兩個函數還是有區別的:

① setInterval()會多次執行要定時執行的代碼或函數。經過了那個固定的時間間隔,它還會自動重復執行代碼。

② setTimeout()只會執行一次那段代碼或者指定的函數。

1.循環執行

下面的JS語句實現的是每過十分鐘執行一次circulateExecute()方法。

//循環執行,每十分鐘一次。10分鐘後第一次執行。
setInterval("circulateExecute();",10*60*1000);//10分鐘執行一次

2.下一個整點,或者某個時刻定點執行

以下javascript代碼實現的是實現在當前時刻的下一個整點定點執行nextIntegralPointAfterLogin()方法。

var date = new Date();//現在時刻
var dateIntegralPoint = new Date();//用戶登錄時刻的下一個整點,也可以設置成某一個固定時刻
dateIntegralPoint.setHours(date.getHours()+1);//小時數增加1
dateIntegralPoint.setMinutes(0);
dateIntegralPoint.setSeconds(0);
setTimeout("nextIntegralPointAfterLogin();",dateIntegralPoint-date);//用戶登錄後的下一個整點執行。

3.每一個整點定點執行

通過上面介紹的在下一個整點執行nextIntegralPointAfterLogin()函數後,為了實現在每一個整點都執行某函數,可以在nextIntegralPointAfterLogin()函數中寫上以下代碼。

function nextIntegralPointAfterLogin(){

     IntegralPointExecute();//在整點執行的函數,在每個整點都調用該函數
setInterval("IntegralPointExecute();",60*60*1000);//一個小時執行一次,那麼下一個整點,下下一個整點都會執行

}
注意:由於JS計算的誤差以及執行過程中需要一定的時間,所以上述定時定點執行方法可能會有一兩秒的誤差。

以上這篇JS定時器使用,定時定點,固定時刻,循環執行詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved