我如何在全天中获得 2 个日期之间的差异(我不想要一天的任何部分)
var date1 = new Date('7/11/2010');
var date2 = new Date('12/12/2010');
var diffDays = date2.getDate() - date1.getDate();
alert(diffDays)
我尝试了上面的方法,但这没有用。
我如何在全天中获得 2 个日期之间的差异(我不想要一天的任何部分)
var date1 = new Date('7/11/2010');
var date2 = new Date('12/12/2010');
var diffDays = date2.getDate() - date1.getDate();
alert(diffDays)
我尝试了上面的方法,但这没有用。
const date1 = new Date('7/13/2010');
const date2 = new Date('12/15/2010');
const diffTime = Math.abs(date2 - date1);
const diffDays = Math.ceil(diffTime / (1000 * 60 * 60 * 24));
console.log(diffTime + " milliseconds");
console.log(diffDays + " days");
请注意,我们需要将日期括在引号中。其余代码获取以毫秒为单位的时间差,然后除以获取天数。日期需要 mm/dd/yyyy 格式。
...因为日期自然具有时区信息,可以跨越具有不同夏令时调整的区域
此问题的先前答案未考虑所讨论的两个日期跨越夏令时 (DST) 更改的情况。DST 更改发生的日期将以毫秒为单位的持续时间为!= 1000*60*60*24
,因此典型计算将失败。
您可以通过首先将两个日期标准化为 UTC,然后计算这两个 UTC 日期之间的差异来解决此问题。
现在,解决方案可以写成,
const _MS_PER_DAY = 1000 * 60 * 60 * 24;
// a and b are javascript Date objects
function dateDiffInDays(a, b) {
// Discard the time and time-zone information.
const utc1 = Date.UTC(a.getFullYear(), a.getMonth(), a.getDate());
const utc2 = Date.UTC(b.getFullYear(), b.getMonth(), b.getDate());
return Math.floor((utc2 - utc1) / _MS_PER_DAY);
}
// test it
const a = new Date("2017-01-01"),
b = new Date("2017-07-25"),
difference = dateDiffInDays(a, b);
这是有效的,因为 UTC 时间从不观察 DST。请参阅UTC 是否遵守夏令时?
ps 在讨论了有关此答案的一些评论之后,一旦您了解了跨越 DST 边界的 javascript 日期问题,解决它的方法可能不止一种。我上面提供的是一个简单(并经过测试)的解决方案。我很想知道是否有一个简单的基于算术/数学的解决方案,而不必实例化两个新的 Date 对象。这可能会更快。
这是使用moment.js的解决方案:
var a = moment('7/11/2010','M/D/YYYY');
var b = moment('12/12/2010','M/D/YYYY');
var diffDays = b.diff(a, 'days');
alert(diffDays);
我使用了您的原始输入值,但您没有指定格式,因此我假设第一个值是 7 月 11 日。如果原定于 11 月 7 日,则将格式调整为D/M/YYYY
。
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 )
我尝试了很多方法,发现使用datepicker 是最好的,但是日期格式会导致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>
一个小提琴可以在这里看到演示