JavaScript计算时间差详解
分类:实例代码
实际应用中,需要计算两个时间点之间的差,很多时候需要精确到天、小时、分钟和秒。
下面通过代码实例简单介绍一下如何实现此效果。
代码实例如下:
<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.pipipi.net/" /> <title>前端教程网</title> <style type="text/css"> #ant{ font-size:2em; } </style> <script type="text/javascript"> function thenceThen() { var theTime="2014/5/4" var endTime=new Date(theTime); var totalSecs=(endTime-new Date())/1000; var days=Math.floor(totalSecs/3600/24); var hours=Math.floor((totalSecs-days*24*3600)/3600); var mins=Math.floor((totalSecs-days*24*3600-hours*3600)/60); var secs=Math.floor((totalSecs-days*24*3600-hours*3600-mins*60)); if(days!=0) { document.getElementById("ant").innerHTML=days+"天"+hours+"小时"+mins+"分钟"+secs+"秒"; } else if(hours==0&&mins==0) { document.getElementById("ant").innerHTML = secs + "秒"; } else if(hours==0&&mins!= 0) { document.getElementById("ant").innerHTML = mins + "分钟" + secs + "秒"; } else if (hours!=0) { document.getElementById("ant").innerHTML = hours + "小时" + mins + "分钟" + secs + "秒"; } } var clock; window.onload=function() { clock=setInterval("thenceThen()",500); } </script> </head> <body> <div id="ant"></div> </body> </html>
一.代码注释:
(1).function thenceThen(){},此函数用来计算时间差距。
(2).var theTime="2014/5/4",此变量用来定义要计算时间差的一个时间点。
(3).var endTime=new Date(theTime),创建当前时间对象。
(4).var totalSecs=(endTime-new Date())/1000,两个时间对象的差是两者之间的毫秒差距,再除以1000就是相差的描述。
(5).var days=Math.floor(totalSecs/3600/24),计算相差的天数,特别注意Math.floor()函数的作用,可以参看相关阅读。
(6).var hours=Math.floor((totalSecs-days*24*3600)/3600),计算相差的小时数。
二.相关阅读:
(1).Date()构造函数的参数参阅JavaScript Date()构造函数参数一章节。
(2). Math.floor()函数参阅javascript Math.floor()一章节。
(3).innerHTML属性参阅js innerHTML属性的用法一章节。
JavaScript计算时间差详解,这样的场景在实际项目中还是用的比较多的,关于JavaScript计算时间差详解就介绍到这了。
JavaScript计算时间差详解属于前端实例代码,有关更多实例代码大家可以查看。