javascript倒計(jì)時(shí)功能實(shí)現(xiàn)代碼
更新時(shí)間:2012年06月07日 23:52:51 作者:
javascript倒計(jì)時(shí)功能實(shí)現(xiàn)代碼,需要的朋友可以參考下
代碼如下:
/**
* 倒計(jì)時(shí)
*
* @author WadeYu
* @date 2012-04-20 17:40
* @copyright boyaa.com
*/
var TimeCountDown = function( initTime ){
var day = 0;
var hour = 0;
var minute = 0;
var second = 0;
var timerId = 0;
var self = this;
var fixInitTime = function(){
initTime = parseInt(initTime);
if ( isNaN(initTime) || initTime < 0 ){
initTime = 0;
}
};
var fixZero = function(num){
return num < 10 ? ('0'+num) : num;
};
var calc = function(){
showCallback.call(self, [fixZero(day), fixZero(hour), fixZero(minute), fixZero(second)]);
if ( day === 0 && hour === 0 && minute === 0 && second === 0){
self.stop();
} else {
if (hour === 0 && day > 0){
hour = 24;
day--;
}
if (minute === 0 && hour > 0){
minute = 60;
hour--;
}
if (second === 0 && minute > 0){
second = 59;
minute--;
} else {
second--;
}
timerId = window.setTimeout(function(){
calc();
}, 1000);
}
};
var showCallback = function(){
alert('Please set show callback functions!');
};
var init = function(){
fixInitTime();
if ( initTime > 0 ){
day = Math.floor( (initTime / (24*60*60)) );
initTime -= day * 24*60*60;
hour = Math.floor( initTime / (60*60) );
initTime -= hour * 60*60;
minute = Math.floor( initTime / 60 );
second = initTime - minute * 60;
}
};
this.start = function(){
calc();
};
this.stop = function(){
timerId && window.clearTimeout(timerId);
};
this.setShowCallback = function(fn){
typeof(fn) === 'function' ? (showCallback = fn) : '';
};
init();
};
示例如下:
<body>
<div id="timeCon"></div>
<script type="text/javascript">
var timeCountDown = new TimeCountDown(3 * 24 * 60 * 60);
timeCountDown.setShowCallback(function( obj ){ // [天, 小時(shí), 分, 秒]
document.getElementById('timeCon').innerHTML = obj[0] + ":" + obj[1] + ":" + obj[2] + ':' + obj[3];
});
timeCountDown.start();
</script>
</body>
復(fù)制代碼 代碼如下:
/**
* 倒計(jì)時(shí)
*
* @author WadeYu
* @date 2012-04-20 17:40
* @copyright boyaa.com
*/
var TimeCountDown = function( initTime ){
var day = 0;
var hour = 0;
var minute = 0;
var second = 0;
var timerId = 0;
var self = this;
var fixInitTime = function(){
initTime = parseInt(initTime);
if ( isNaN(initTime) || initTime < 0 ){
initTime = 0;
}
};
var fixZero = function(num){
return num < 10 ? ('0'+num) : num;
};
var calc = function(){
showCallback.call(self, [fixZero(day), fixZero(hour), fixZero(minute), fixZero(second)]);
if ( day === 0 && hour === 0 && minute === 0 && second === 0){
self.stop();
} else {
if (hour === 0 && day > 0){
hour = 24;
day--;
}
if (minute === 0 && hour > 0){
minute = 60;
hour--;
}
if (second === 0 && minute > 0){
second = 59;
minute--;
} else {
second--;
}
timerId = window.setTimeout(function(){
calc();
}, 1000);
}
};
var showCallback = function(){
alert('Please set show callback functions!');
};
var init = function(){
fixInitTime();
if ( initTime > 0 ){
day = Math.floor( (initTime / (24*60*60)) );
initTime -= day * 24*60*60;
hour = Math.floor( initTime / (60*60) );
initTime -= hour * 60*60;
minute = Math.floor( initTime / 60 );
second = initTime - minute * 60;
}
};
this.start = function(){
calc();
};
this.stop = function(){
timerId && window.clearTimeout(timerId);
};
this.setShowCallback = function(fn){
typeof(fn) === 'function' ? (showCallback = fn) : '';
};
init();
};
示例如下:
復(fù)制代碼 代碼如下:
<body>
<div id="timeCon"></div>
<script type="text/javascript">
var timeCountDown = new TimeCountDown(3 * 24 * 60 * 60);
timeCountDown.setShowCallback(function( obj ){ // [天, 小時(shí), 分, 秒]
document.getElementById('timeCon').innerHTML = obj[0] + ":" + obj[1] + ":" + obj[2] + ':' + obj[3];
});
timeCountDown.start();
</script>
</body>
您可能感興趣的文章:
- JS實(shí)現(xiàn)用戶注冊(cè)時(shí)獲取短信驗(yàn)證碼和倒計(jì)時(shí)功能
- JS實(shí)現(xiàn)表單驗(yàn)證功能(驗(yàn)證手機(jī)號(hào)是否存在,驗(yàn)證碼倒計(jì)時(shí))
- js實(shí)現(xiàn)發(fā)送驗(yàn)證碼后的倒計(jì)時(shí)功能
- php+js實(shí)現(xiàn)倒計(jì)時(shí)功能
- js實(shí)現(xiàn)網(wǎng)頁倒計(jì)時(shí)、網(wǎng)站已運(yùn)行時(shí)間功能的代碼3例
- JavaScript在控件上添加倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼
相關(guān)文章
JavaScript Date對(duì)象 日期獲取函數(shù)
JavaScript Date對(duì)象 日期獲取函數(shù)必備,需要使用js得到當(dāng)前日期的朋友可以參考下。2010-12-12
利用js獲取服務(wù)器時(shí)間的兩個(gè)簡(jiǎn)單方法
js獲取服務(wù)器時(shí)間的兩個(gè)方法,代碼比較簡(jiǎn)單,需要的朋友可以參考下。2010-01-01
Js 獲取當(dāng)前日期時(shí)間及其它操作實(shí)現(xiàn)代碼
比較不錯(cuò)的js日期時(shí)間獲取函數(shù),比較全面,也比較容易拓展。2009-03-03
javascript 時(shí)間顯示代碼集合(Date對(duì)象)
javascript提供了Date對(duì)象來進(jìn)行時(shí)間和日期的計(jì)算,所以我們后面的很多代碼都是通過Date對(duì)象實(shí)現(xiàn)的,大家多看一些實(shí)例就可以自己拓展了2012-09-09
firefox getyear() getFullYear數(shù)獲取年份的問題
Javascript getYear()函數(shù)問題,一般需要用getFullYear2008-12-12
JS 操作日期 順便實(shí)現(xiàn) 上一周 和 下一周 功能
JS本身沒有提供日期加減操作能力,所以借此寫了幾個(gè)方法,用以操作日期,主要是實(shí)現(xiàn)日期的加減2009-10-10

