本文实例讲述了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:这里再为大家推荐几款时间及日期相关工具供大家参考使用:
在线日期/天数计算器:
http://tools.jb51.net/jisuanqi/date_jisuanqi
在线日期计算器/相差天数计算器:
http://tools.jb51.net/jisuanqi/datecalc
在线日期天数差计算器:
http://tools.jb51.net/jisuanqi/onlinedatejsq
Unix时间戳(timestamp)转换工具:
http://tools.jb51.net/code/unixtime
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript时间与日期操作技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
JS,给定时间,倒计时
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- [发烧人声]群星《邂逅》DTS-WAV
- 艻打绿《夏/狂热(苏打绿版)》[320K/MP3][106.42MB]
- 艻打绿《夏/狂热(苏打绿版)》[FLAC分轨][574.2MB]
- 黄雨勳《魔法列车首部曲》[320K/MP3][33.1MB]
- 李蕙敏.2014-记得·销魂新歌+精丫乐意唱片】【WAV+CUE】
- 谢金燕.1995-含泪跳恰蔷冠登】【WAV+CUE】
- 于文文.2024-天蝎座【华纳】【FLAC分轨】
- 黄雨勳《魔法列车首部曲》[FLAC/分轨][173.61MB]
- 群星《歌手2024 第13期》[320K/MP3][50.09MB]
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV
- VA-Hair(OriginalBroadwayCastRecording)(1968)(PBTHAL24-96FLAC)
- 博主分享《美末2RE》PS5 Pro运行画面 玩家仍不买账
- 《双城之战2》超多新歌MV发布:林肯公园再次献声