如何计算全天两个日期之间的差异(我不想要一天的分数)

var date1 = new Date('7/11/2010');
var date2 = new Date('12/12/2010');
var diffDays = date2.getDate() - date1.getDate(); 
alert(diffDays)

我尝试了以上方法,但没有成功。


当前回答

这是从另一个日期减去一个日期的代码。此示例将日期转换为对象,因为getTime()函数将不起作用,除非它是Date对象。

    var dat1 = document.getElementById('inputDate').value;
                var date1 = new Date(dat1)//converts string to date object
                alert(date1);
                var dat2 = document.getElementById('inputFinishDate').value;
                var date2 = new Date(dat2)
                alert(date2);

                var oneDay = 24 * 60 * 60 * 1000; // hours*minutes*seconds*milliseconds
                var diffDays = Math.abs((date1.getTime() - date2.getTime()) / (oneDay));
                alert(diffDays);

其他回答

这是从另一个日期减去一个日期的代码。此示例将日期转换为对象,因为getTime()函数将不起作用,除非它是Date对象。

    var dat1 = document.getElementById('inputDate').value;
                var date1 = new Date(dat1)//converts string to date object
                alert(date1);
                var dat2 = document.getElementById('inputFinishDate').value;
                var date2 = new Date(dat2)
                alert(date2);

                var oneDay = 24 * 60 * 60 * 1000; // hours*minutes*seconds*milliseconds
                var diffDays = Math.abs((date1.getTime() - date2.getTime()) / (oneDay));
                alert(diffDays);

我尝试了很多方法,发现使用日期选择器是最好的,但日期格式会导致JavaScript出现问题。。。。

这是我的答案,可以开箱即用。

<input type="text" id="startdate">
<input type="text" id="enddate">
<input type="text" id="days">

<script src="https://code.jquery.com/jquery-1.8.3.js"></script>
<script src="https://code.jquery.com/ui/1.10.0/jquery-ui.js"></script>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/redmond/jquery-ui.css" />
<script>
$(document).ready(function() {

$( "#startdate,#enddate" ).datepicker({
changeMonth: true,
changeYear: true,
firstDay: 1,
dateFormat: 'dd/mm/yy',
})

$( "#startdate" ).datepicker({ dateFormat: 'dd-mm-yy' });
$( "#enddate" ).datepicker({ dateFormat: 'dd-mm-yy' });

$('#enddate').change(function() {
var start = $('#startdate').datepicker('getDate');
var end   = $('#enddate').datepicker('getDate');

if (start<end) {
var days   = (end - start)/1000/60/60/24;
$('#days').val(days);
}
else {
alert ("You cant come back before you have been!");
$('#startdate').val("");
$('#enddate').val("");
$('#days').val("");
}
}); //end change function
}); //end ready
</script>

在这里可以看到一个Fiddle演示

更正确的解决方案

……因为日期自然具有时区信息,可以跨地区进行不同的日间光照节省调整

以前对这个问题的回答没有考虑到问题中的两个日期跨越夏时制(DST)变化的情况。DST更改发生的日期将具有以毫秒为单位的持续时间,即!=1000*60*60*24,因此典型计算将失败。

您可以通过首先将两个日期标准化为UTC,然后计算这两个UTC日期之间的差异来解决这个问题。

现在,解决方案可以写成,

//a和b是javascript Date对象函数dateDiffInDays(a,b){常量_MS_PER_DAY=1000*60*60*24;//放弃时间和时区信息。const utc1=日期UTC(a.getFullYear(),a.getMonth(),a.getDate());const utc2=日期UTC(b.getFullYear(),b.getMonth(),b.getDate());返回数学楼层((utc2-utc1)/MS_PER_DAY);}//测试它const a=新日期(“2017-01-01”),b=新日期(“2017-07-25”),difference=日期DiffInDays(a,b);console.log(差异+“天”)

这是因为UTC时间从不遵守DST。请参阅UTC是否遵守夏时制?

p.s.在讨论了对这个答案的一些评论之后,一旦您了解了跨越DST边界的javascript日期的问题,解决它的方法可能不止一种。我上面提供的是一个简单的(经过测试的)解决方案。我很想知道是否有一个简单的基于算术/数学的解决方案,而不是必须实例化两个新的Date对象。这可能会更快。

var date1 = new Date("7/11/2010");
var date2 = new Date("8/11/2010");
var diffDays = parseInt((date2 - date1) / (1000 * 60 * 60 * 24), 10); 

alert(diffDays )

这里有一种方法:

const date1=新日期(2010年7月13日);const date2=新日期(2010年12月15日);const diffTime=数学.abs(date2-date1);const diffDays=数学ceil(diffTime/(1000*60*60*24));console.log(diffTime+“毫秒”);console.log(diffDays+“天”);

注意,我们需要将日期用引号括起来。其余的代码以毫秒为单位获取时间差,然后除以得到天数。日期应为mm/dd/yyyy格式。