您的位置:首页 > Web前端 > JavaScript

奇怪的Js时间计算方法,跨多个月后出现1天的误差

2013-08-06 11:30 218 查看
在项目中要求用计算两个时间相差的天数,通俗的说就是两个时间 相减,

我的方法 先把两个时间转成相应的毫秒,相减后,再除以(1000 * 60 * 60 * 24) 就可以得到对应天数,但天数会比实际少一天所以需要再加上一天

代码如下

function DateDiff() {
//startTime和endTime是18/12/2002格式
var startTime = $("#<%=txtDepartureDate.ClientID %>").val();
var endTime = $("#<%=txtReturnDate.ClientID %>").val();

var newDate, sDate, eDate, iDays

newDate = startTime.split("/")
sDate = new Date(aDate[2], aDate[1]-1, aDate[0])

newDate = endTime.split("/")
eDate = new Date(aDate[2], aDate[1]-1, aDate[0])
iDays = Math.floor((eDate2 - sDate) / 86400000)
alert(iDays+1);
}


当时测试没有跨好几个月,发现都没有问题,直到测试人员提了BUG然后自己仔细测终于发现了

BUG:开始日期为:06/08/2013 结束日期为:30/11/2013 计算的结果为116

然后将结束日期改为:01/12/2013 计算的结果居然为118,无缘无故的多出来了1天

然后偿试换种写法方法式都是把时间转成毫秒后相减再除(1000 * 60 * 60 * 24) 结果都多了一天,

最后查看了JS 文档才知道原来 Js Moth默认是从0开始的,所以应该把月都减1



Date(aDate[2], aDate[1]-1, aDate[0])
这样计算就会得到正确的天数

还有一种用C#代码去算也是可以的代码如下:

int nights =0;
if (!string.IsNullOrEmpty(startTime) && !string.IsNullOrEmpty(endTime))
{
System.TimeSpan td = Convert.ToDateTime(endTime) - Convert.ToDateTime(startTime);
nights = td.Days + 1;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: