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计算时间差详解属于前端实例代码,有关更多实例代码大家可以查看

回复

我来回复
  • 暂无回复内容