JS实现针对给定时间的倒计时功能示例
程序员文章站
2022-05-15 08:16:13
本文实例讲述了js实现针对给定时间的倒计时功能。分享给大家供大家参考,具体如下:
有时候,网站需要一个倒计时的特效来庆祝某些特别的日子。自己也实现了一个,占用内存也很小噢...
本文实例讲述了js实现针对给定时间的倒计时功能。分享给大家供大家参考,具体如下:
有时候,网站需要一个倒计时的特效来庆祝某些特别的日子。自己也实现了一个,占用内存也很小噢。其原理就是每隔一秒执行一次处理函数,将终点时间和现在的时间比较然后换算之后显示对应的值。
效果如下:
代码如下:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>倒计时</title> </head> <body> <input type="text" name="time" id="time" value="2017-09-22" /> <input type="button" name="okbtn" id="okbtn" value="确认" /> <br /> <p id="textp">这里显示倒计时</p> </body> <script type="text/javascript"> var okbtn=document.getelementbyid("okbtn"); textp=document.getelementbyid("textp"); okbtn.onclick=function(){ var time=document.getelementbyid("time"); var timevalue=time.value; //通过正则表达式确认输入格式是否正确 var patt=/^(\d{1,4})(-)(\d{1,2})\2(\d{1,2})$/; if(patt.test(timevalue)==false){ //如果不正确 textp.innerhtml="输入格式不满足yyyy-mm-dd"; return false; }else{ textp.innerhtml="这里显示倒计时"; } //获取输入的年月日 var timearray=timevalue.split("-"); //showlefttime(timearray[0],timearray[1],timearray[2]); setinterval(function(){showlefttime(timearray[0],timearray[1],timearray[2]);},1000); } function showlefttime(year,month,date){ //得出剩余时间 var now=new date(); var enddate=new date(year,month-1,date); var lefttime=enddate.gettime()-now.gettime(); var leftsecond=parseint(lefttime/1000); var day=math.floor(leftsecond/(60*60*24)); var hour=math.floor((leftsecond-day*24*60*60)/3600); var minute=math.floor((leftsecond-day*24*60*60-hour*3600)/60); var second=math.floor(leftsecond-day*60*60*24-hour*60*60-minute*60); //显示剩余时间 textp.innerhtml="距离"+year+"年"+month+"月"+date+"日" +"还有"+day+"天"+hour+"小时"+minute+"分"+second+"秒"; } </script> </html>
ps:这里再为大家推荐几款时间及日期相关工具供大家参考使用:
在线日期/天数计算器:
在线日期计算器/相差天数计算器:
在线日期天数差计算器:
unix时间戳(timestamp)转换工具:
更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript时间与日期操作技巧总结》、《javascript查找算法技巧总结》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结》
希望本文所述对大家javascript程序设计有所帮助。