首页 > 代码库 > JS倒计时代码
JS倒计时代码
第一种:精确到秒的javascript倒计时代码
HTML代码:
<formname="form1">
<div align="center"align="center">
<center>离2010年还有:<br>
<input type="textarea" name="left" size="35"style="text-align:center">
</center>
</div>
</form>
<scriptLANGUAGE="javascript">
startclock()
var timerID = null;
var timerRunning = false;
function showtime() {
Today = new Date();
var NowHour =Today.getHours();
var NowMinute =Today.getMinutes();
var NowMonth =Today.getMonth();
var NowDate =Today.getDate();
var NowYear =Today.getYear();
var NowSecond =Today.getSeconds();
if (NowYear<2000)
NowYear=1900+NowYear;
Today = null;
Hourleft = 23 - NowHour
Minuteleft = 59 -NowMinute
Secondleft = 59 -NowSecond
Yearleft = 2009 - NowYear
Monthleft = 12 - NowMonth - 1
Dateleft = 31 - NowDate
if(Secondleft<0)
{
Secondleft=60+Secondleft;
Minuteleft=Minuteleft-1;
}
if(Minuteleft<0)
{
Minuteleft=60+Minuteleft;
Hourleft=Hourleft-1;
}
if(Hourleft<0)
{
Hourleft=24+Hourleft;
Dateleft=Dateleft-1;
}
if(Dateleft<0)
{
Dateleft=31+Dateleft;
Monthleft=Monthleft-1;
}
if(Monthleft<0)
{
Monthleft=12+Monthleft;
Yearleft=Yearleft-1;
}
Temp=Yearleft+‘年, ‘+Monthleft+‘月, ‘+Dateleft+‘天, ‘+Hourleft+‘小时,‘+Minuteleft+‘分, ‘+Secondleft+‘秒‘
document.form1.left.value=http://www.mamicode.com/Temp;
timerID =setTimeout("showtime()",1000);
timerRunning = true;
}
var timerID = null;
var timerRunning = false;
function stopclock () {
if(timerRunning)
clearTimeout(timerID);
timerRunning = false;
}
function startclock () {
stopclock();
showtime();
}
// -->
</script>
第二种:某某运动会
HTML代码:
<!--倒计时Javascriptbegin-->
<scriptlanguage="JavaScript">
<!--
function DigitalTime1()
{
var deadline= new Date("08/13/2007")//开幕倒计时
var symbol="8月13日"
var now = new Date()
var diff = -480 - now.getTimezoneOffset()//是北京时间和当地时间的时间差
var leave = (deadline.getTime() - now.getTime()) + diff*60000
var day = Math.floor(leave / (1000 * 60 * 60 *24))
var hour = Math.floor(leave / (1000*3600)) - (day *24)
var minute = Math.floor(leave / (1000*60)) - (day * 24 *60) - (hour* 60)
var second = Math.floor(leave / (1000)) - (day * 24 *60*60) - (hour* 60 * 60) - (minute*60)
var deadline_2= new Date("08/13/2004")//开幕后计时
var symbol_2="8月13日"
var now_2 = new Date()
var diff_2 = -480 - now.getTimezoneOffset()//是北京时间和当地时间的时间差
var leave_2 = (now_2.getTime() - deadline_2.getTime()) +diff_2*60000
var day_2 = Math.floor(leave_2 / (1000 * 60 * 60 *24))
var hour_2 = Math.floor(leave_2 / (1000*3600)) - (day_2 *24)
var minute_2 = Math.floor(leave_2 / (1000*60)) - (day_2 * 24 *60) -(hour_2 * 60)
var second_2 = Math.floor(leave_2 / (1000)) - (day_2 * 24 *60*60) -(hour_2 * 60 * 60) -(minute_2*60)
day=day+1;
day_2=day_2+1;
if (day>0)//还未开幕
{
//LiveClock1.innerHTML ="现在"+symbol+"天"
LiveClock1.innerHTML = "<font
setTimeout("DigitalTime1()",1000)
}
if (day<0)//已经开幕
{
//LiveClock1.innerHTML ="现在离"+symbol+"还有"+day+"天"+hour+"小时"+minute+"分"+second+"秒"
LiveClock1.innerHTML = "<font
setTimeout("DigitalTime1()",1000)
}
if (day==0) //正在开幕
{
//LiveClock1.innerHTML ="现在"+symbol+"天"
LiveClock1.innerHTML = "<font
setTimeout("DigitalTime1()",1000)
}
if (day<0 & day_2>19)//某某运动会结束
{
//LiveClock1.innerHTML ="现在离"+symbol+"还有"+day+"天"+hour+"小时"+minute+"分"+second+"秒"
LiveClock1.innerHTML = "<font
setTimeout("DigitalTime1()",1000)
}
}
// -->
</script>
<!--倒计时Javascriptend-->
<bodyonload=DigitalTime1()>
<div id=LiveClock1></div>
</body>
第三种:小时倒计时
HTML代码:
<SCRIPTLANGUAGE="JavaScript">
<!--
var maxtime = 60*60//一个小时,按秒计算,自己调整!
function CountDown(){
if(maxtime>=0){
minutes =Math.floor(maxtime/60);
seconds =Math.floor(maxtime`);
msg ="距离结束还有"+minutes+"分"+seconds+"秒";
document.all["timer"].innerHTML=msg;
if(maxtime == 5*60)alert(‘注意,还有5分钟!‘);
--maxtime;
}
else{
clearInterval(timer);
alert("时间到,结束!");
}
}
timer =setInterval("CountDown()",1000);
//-->
</SCRIPT>
<div id="timer"style="color:red"></div>
第四种:最简倒计时
HTML代码:
<ScriptLanguage="JavaScript">
<!--Begin
var timedate= new Date("January14,2006");
vartimes="研究生考试";
var now = newDate();
var date = timedate.getTime() -now.getTime();
var time = Math.floor(date / (1000 * 60 * 60 *24));
if (time >= 0);
document.write("<li><fontcolor=#DEDBDE>现在离2006年"+times+"还有:<fontcolor=#ffffff><b>"+time+"</b></font>天</font></li>");
// End -->
</Script>
第五种:最简倒计时二
HTML代码:
<script language="JavaScript"type="text/javascript">
function djs(){
var urodz= newDate("11/12/2008");
var now = new Date();
var num
var ile = urodz.getTime() -now.getTime();
var dni = Math.floor(ile / (1000 * 60 * 60 *24));
if (dni>1)
num=dni+1
else if (dni == 1) num=2
else if (dni == 0) num=1
else num=0
document.write(num)
}
</script>
距某某开幕式还有 [<script language="JavaScript"type="text/javascript">djs()</script>]天
第五个:Javascript倒计时器 -采用系统时间自校验
这次利用系统时间自校验倒计时, 无需手工调校使得倒计时更为精确,代码及详细注释如下:
<spanid="clock">00:01:11:00</span>
<input id="startB" type="button" value="http://www.mamicode.com/start"onclick="run()">
<input id="endB" type="button" value="http://www.mamicode.com/stop"onclick="stop()">
<br>
<input id="diff"type="text">
<input id="next"type="text">
<scriptlanguage="Javascript">
var normalelapse = 100;
var nextelapse =normalelapse;
varcounter;
var startTime;
var start =clock.innerText;
var finish ="00:00:00:00";
var timer = null;
// 开始运行
function run() {
startB.disabled = true;
endB.disabled = false;
counter = 0;
// 初始化开始时间
startTime = newDate().valueOf();
// nextelapse是定时时间,初始时为100毫秒
// 注意setInterval函数: 时间逝去nextelapse(毫秒)后,onTimer才开始执行
timer = window.setInterval("onTimer()",nextelapse);
}
// 停止运行
function stop() {
startB.disabled = false;
endB.disabled = true;
window.clearTimeout(timer);
}
window.onload = function(){
endB.disabled = true;
}
// 倒计时函数
function onTimer()
{
if (start == finish)
{
window.clearInterval(timer);
alert("time is up!");
return;
}
var hms = newString(start).split(":");
var ms = newNumber(hms[3]);
var s = newNumber(hms[2]);
var m = newNumber(hms[1]);
var h = newNumber(hms[0]);
ms -= 10;
if (ms <0)
{
ms = 90;
s -= 1;
if (s < 0)
{
s =59;
m -=1;
}
if (m < 0)
{
m =59;
h -=1;
}
}
var ms = ms < 10 ? ("0" + ms) :ms;
var ss = s < 10 ? ("0" + s) :s;
var sm = m < 10 ? ("0" + m) :m;
var sh = h < 10 ? ("0" + h) :h;
start = sh + ":" + sm + ":" + ss + ":" +ms;
clock.innerText = start;
// 清除上一次的定时器
window.clearInterval(timer);
// 自校验系统时间得到时间差,并由此得到下次所启动的新定时器的时间nextelapse
counter++;
var counterSecs = counter *100;
var elapseSecs = new Date().valueOf() -startTime;
var diffSecs = counterSecs -elapseSecs;
nextelapse = normalelapse +diffSecs;
diff.value = http://www.mamicode.com/counterSecs +"-" + elapseSecs + "=" +diffSecs;
next.value = "http://www.mamicode.com/nextelapse =" +nextelapse;
if (nextelapse < 0) nextelapse =0;
// 启动新的定时器
timer = window.setInterval("onTimer()",nextelapse);
}
</script>
JS倒计时代码