JS倒计时代码

分类:Javascript| 发布:camnprbubuol| 查看: | 发表时间:2010/9/25

第一种:精确到秒的javascript倒计时代码  

HTML代码:  

<form name="form1">
 <div align="center" align="center">
  <center>
离2011年还有:<br>
<input type="textarea" name="left" size="35" style="text-align: center">
  </center>
 </div>
 </form>

 <script language="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 = 2011 - 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=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代码:  
<head>
<!--倒计时Javascript begin-->
    <script type="text/javascript"><!--
     function DigitalTime()  
     {   
         var deadline= new Date("03/12/2011") //开幕倒计时  
         var symbol="3月12日" 
         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("12/01/2010") //开幕后计时  
         var symbol_2="12月01日" 
         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 class=fon1>距离"+symbol+"开幕还有<font class=fon2>"+day+"</font>天</font>" 
             setTimeout("DigitalTime()",1000)  
         }  
         
         if (day<0) //已经开幕  
         {  
             //LiveClock1.innerHTML = "现在离"+symbol+"还有"+day+"天"+hour+"小时"+minute+"分"+second +"秒"  
             LiveClock1.innerHTML = "<font class=fon1>"+symbol+"开幕已有<font class=fon2>"+day_2+"</font>天</font>" 
             setTimeout("DigitalTime()",1000)  
         
         }  
         if (day==0) //正在开幕  
         {  
             //LiveClock1.innerHTML = "现在"+symbol+"天"  
             LiveClock1.innerHTML = "<font class=fon1>某某运动会今天开幕</font>" 
             setTimeout("DigitalTime()",1000)  
         }
           
         if (day<0 & day_2>19) //某某运动会结束  
         {  
             //LiveClock1.innerHTML = "现在离"+symbol+"还有"+day+"天"+hour+"小时"+minute+"分"+second +"秒"  
             LiveClock1.innerHTML = "<font class=fon1>某某运动会已全部结束</font>" 
             setTimeout("DigitalTime()",1000)  
         
         }  
     
     }  
// --></script>
<!--倒计时Javascript end-->
</head>
<body onload="DigitalTime()">
<div id="LiveClock1"></div>
</body> 

第三种:小时倒计时  


HTML代码:  
<SCRIPT LANGUAGE="JavaScript">  
<!--  
var maxtime = 60*60 //一个小时,按秒计算,自己调整!  
function CountDown(){  
if(maxtime>=0){  
minutes = Math.floor(maxtime/60);  
seconds = Math.floor(maxtime%60);  
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代码:  
<Script Language="JavaScript">   
<!-- Begin   
  var timedate= new Date("January 14,2006");   
  var times="研究生考试";   
  var now = new Date();   
  var date = timedate.getTime() - now.getTime();   
  var time = Math.floor(date / (1000 * 60 * 60 * 24));   
  if (time >= 0) ;  
document.write("<li><font color=#DEDBDE>现在离2006年"+times+"还有: <font color=#ffffff><b>"+time +"</b></font> 天</font></li>");  
// End -->  
</Script>  


第五种:最简倒计时二  



HTML代码:  
<script language="JavaScript" type="text/javascript">  
function djs(){  
var urodz= new Date("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倒计时器 - 采用系统时间自校验  
这次利用系统时间自校验倒计时, 无需手工调校使得倒计时更为精确, 代码及详细注释如下:  

<span id="clock">00:01:11:00</span>  
<input id="startB" type="button" value="start countdown!" onclick="run()">  
<input id="endB" type="button" value="stop countdown!" onclick="stop()">  
<br>  
<input id="diff" type="text">  
<input id="next" type="text">  
<script language="Javascript">  
var normalelapse = 100;  
var nextelapse = normalelapse;  
var counter;   
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 = new Date().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 = new String(start).split(":");  
var ms = new Number(hms[3]);  
var s = new Number(hms[2]);  
var m = new Number(hms[1]);  
var h = new Number(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 = counterSecs + "-" + elapseSecs + "=" + diffSecs;  
next.value = "nextelapse = " + nextelapse;  
if (nextelapse < 0) nextelapse = 0;  

// 启动新的定时器  
timer = window.setInterval("onTimer()", nextelapse);   
}  
</script>

 

商城中常用的倒计时

<p>商品抢购倒计时中…</p>
<p>此商品抢购时间还有<span id="_lefttime" style="color:red;font-size:18pt;"></span></p>
<script type="text/javascript">
function _fresh()
{
 var endtime=new Date("December 20, 2010 20:00:00");
 var nowtime = new Date();
 var leftsecond=parseInt((endtime.getTime()-nowtime.getTime())/1000);
 if(leftsecond<0){leftsecond=0;}
 __d=parseInt(leftsecond/3600/24);
 __h=parseInt((leftsecond/3600)%24);
 __m=parseInt((leftsecond/60)%60);
 __s=parseInt(leftsecond%60);
 document.getElementById("_lefttime").innerHTML=__d+"天 "+__h+"小时"+__m+"分"+__s+"秒";
}
_fresh()
setInterval(_fresh,1000);
</script>

365据说看到好文章不转的人,服务器容易宕机
原创文章如转载,请注明:转载自郑州网建-前端开发 http://camnpr.com/
本文链接:http://camnpr.com/archives/46.html