JavaScript实现简单的数字倒计时

这里是一个JavaScript中显示倒计时的方法,从10一秒一秒地往下减直到计时结束(即0),代码如下:

runCount(10);
function runCount(t){
  if(t>0){
    document.getElementById(‘shownum').innerHTML = t;
    t–;
    setTimeout(function(){runCount(t);},1000);
  }else{
    document.getElementById(‘shownum').innerHTML = ‘倒计时结束!';
  }
}

  运行该js代码前,需要先添加一个id为shownum的div。

js实现动态倒计时功能 * a是从后台接收到的时间戳,需转换成毫秒单位

<div>
  距明年还有:
  <span id='daya'></span>天
  <span id='hoursa'></span>小时
  <span id='minua'></span>分
  <span id='secoa'></span>秒
</div>
<script type="text/javascript">
/**
*
*  copyright WE 2012.7
*  js实现动态倒计时功能
*  a是从后台接收到的时间戳,需转换成毫秒单位
*
*/
  var a=12345678;     //以毫秒为单位
  function fomtime()
  {
    a=a-1000;
    var b=new Date();
    b.setTime(0);
    var c=new Date();
    c.setTime(a);
    var day1=b.getDate();    //为方便调用,把天数、小时等单独定义
    var hours1=b.getHours();
    var minu1=b.getMinutes();
    var seco1=b.getSeconds();
    var day2=c.getDate();
    var hours2=c.getHours();
    var minu2=c.getMinutes();
    var seco2=c.getSeconds();
    var day=day2-day1;
    var hours=hours2-hours1;
    var minu=minu2-minu1;
    var seco=seco2-seco1;
    document.getElementById('daya').innerHTML=day;
    document.getElementById('hoursa').innerHTML=hours;
    document.getElementById('minua').innerHTML=minu;
    document.getElementById('secoa').innerHTML=seco;
    setTimeout("fomtime()",1000);
  }
  fomtime();
</script>

按天倒计时

HTML代码1:

<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代码2:

<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倒计时代码

HTML代码:

<form name="form1">
<div align="center" align="center">
<center>离2013年还有:<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 = 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=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代码:

<!--倒计时Javascript begin-->
<script language="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>
<!--倒计时Javascript end-->
<body onload=DigitalTime1()>
<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>

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>

以上所述就是本文的全部内容了,希望大家能够喜欢。

(0)

相关推荐

  • javascript同步服务器时间和同步倒计时小技巧

    之前在网上看到有人提问,如何在页面上同步显示服务器的时间,其实实现方法有几种,可能 一般人立马就想到可以使用Ajax每隔一秒去请求服务器,然后将服务器获取到时间显示在页面上,这样虽然能够实现,但存在一个很大的问题,那就是每隔一秒 去请求服务器,这样如果用户多了,服务器就会崩溃(内存占用率会很大),所以在我看来,这种方法不可行,我这里给出一种解决方案,能够实现同步服务器时间.同步倒计时,却不占用服务器太多资源,下面我给写实现的思路: 第一步,当用户第一次浏览页面时,服务器首先获取当前时间并显示在页

  • javascript页面倒计时实例

    本文实例讲述了javascript页面倒计时实现方法.分享给大家供大家参考.具体实现方法如下: <html> <head> </head> <body> <input type="text" name="mss" id="mss"/> <form action="./index.html"> <input type="text"

  • javascript 实现 秒杀,团购 倒计时展示的记录 分享

    最近做了一个房产的秒杀,团购的电子商务网站(房子也有秒杀,出手不小啊),其中里面有一个秒杀的倒计时展示,主要是判断当前时间距离秒杀开始还有多少时间,还有秒杀开始和秒杀结束的各种展示.其中最主要的一点就是所谓的当前时间不能使用浏览器通过new Date()获取的客户端时间,这样只要用户修改了自己的机器时间那么倒计时就会乱透了,所以这个当前时间必须使用的是服务器时间,所以采用的是静态缓存页面所以这个当前时间使用ajax方式进行获取 复制代码 代码如下: <!DOCTYPE html PUBLIC &qu

  • Javascript倒计时页面跳转实例小结

    例1: 复制代码 代码如下: <script type="text/javascript" language="JavaScript"> var startTime = new Date();    var endTime=startTime.getTime()+10*60*1000;    var g_blinkswitch = 0;    var g_blinktitle = document.title;    function getRemain

  • JavaScript分秒倒计时器实现方法

    本文实例讲述了JavaScript分秒倒计时器实现方法.分享给大家供大家参考.具体分析如下: 一.基本目标 在JavaScript设计一个分秒倒计时器,一旦时间完成使按钮变成不可点击状态 具体效果如下图,为了说明问题,调成每50毫秒也就是每0.05跳一次表, 真正使用的时候,把window.onload=function(){...}中的setInterval("clock.move()",50);从50调成1000即可. 在时间用完之前,按钮还是可以点击的. 时间用完之后,按钮就不能

  • C#结合JavaScript实现秒杀倒计时的方法

    本文实例讲述了C#结合JavaScript实现秒杀倒计时的方法.分享给大家供大家参考.具体如下: 最近做个秒杀活动,要用到倒计时.要求每周三上午10:00开始倒计时 private string Dtime() { byte tempB = (byte)DateTime.Now.DayOfWeek; byte dayByte = (byte)DayOfWeek.Wednesday; DateTime wednesdayNow = DateTime.Now.AddDays(dayByte - te

  • JavaScript实现的一个倒计时的类

    近期在做排列五的彩票项目,每一期都有购彩时段,即用户打开这个排列五的页面时,会从服务器传来一个remaintime(离本次彩期结束的剩余时间),然后这个时间在客户端递减呈现给用户看,让用户获得本次彩期的剩余时间. 实现原理挺简单的,在此不在赘述,运行以下代码查看demo: <!doctype html> <html> <head> <meta http-equiv="Content-Type" content="text/html;

  • javascript实现下班倒计时效果的方法(可桌面通知)

    本文实例讲述了javascript实现下班倒计时效果的方法.分享给大家供大家参考.具体如下: 周末了,搞个下班倒计时,娱乐下. 确保下面三点: 1.非IE浏览器,较高Chrome版本,已开启HTML5桌面通知.具体设置见下面截图 2.将这个HTML放到本地Web服务器上测试,直接双击运行无法弹出桌面通知 顺带提下,这个程序很容易扩展成定时通知. 做这个东西的过程有两点比较纠结,总结下: 1.parseInt("09")返回的是0.正确做法是parseInt("09"

  • javascript倒计时功能实现代码

    代码如下: 复制代码 代码如下: /** * 倒计时 * * @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 =

  • javascript实现倒计时并弹窗提示特效

    在前端开发中,难免会用到倒计时.如做的双十一活动,在距活动开始的半个月前需要做些宣传工作,需要告知用户优惠活动什么时候开始.这个时候就要用到倒计时,如在整站的某个页面提醒用户活动什么时候开始等.而在活动的后期,特别是在距活动结束仅有1天左右时,就要用到弹窗倒计时.这个倒计时设置在整站的首页顶部(当然也可以设置在其它地方,如首页中部等),并设置弹窗弹出10秒后自动消失,由用户决定是否点击到相应的活动页面,购买产品. 需要的技术支持:CSS3,jQuery库: HTML代码如下: <section

  • javascript实现倒计时(精确到秒)

    代码相当简单实用,这里就不多废话了,小伙伴们简单看下就能明白 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <

  • javascript实现促销倒计时+fixed固定在底部

    复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&qu

随机推荐