如何计算两个日期之间的天数

时间:2012-02-03 14:10:32

标签: javascript

我有两个输入日期来自日期选择器控件。我选择了开始日期2/2/2012和结束日期2/7/2012。我已经为此编写了以下代码。

我应该得到结果为6但我得到5。

function SetDays(invoker) {   
    var start = $find('<%=StartWebDatePicker.ClientID%>').get_value();
    var end = $find('<%=EndWebDatePicker.ClientID%>').get_value();

    var oneDay=1000 * 60 * 60 * 24;
    var difference_ms = Math.abs(end.getTime() - start.getTime())
    var diffValue = Math.round(difference_ms / oneDay);
}

有谁能告诉我如何才能得到确切的区别?

8 个答案:

答案 0 :(得分:495)

http://momentjs.com/https://date-fns.org/

来自Moment docs:

var a = moment([2007, 0, 29]);
var b = moment([2007, 0, 28]);
a.diff(b, 'days')   // =1

或包含开头:

a.diff(b, 'days')+1   // =2

手动打乱时间戳和时区。

根据您的具体用例,您可以

  1. 使用a/b.startOf('day')和/或a/b.endOf('day')强制差异在“结尾”包含或排除(如评论中的@kotpal所示)。
  2. 设置第三个参数true以获得浮点差异,然后根据需要Math.floorMath.ceilMath.round
  3. 选项2也可以通过获取'seconds'代替'days'然后除以24*60*60来完成。

答案 1 :(得分:20)

如果您使用的是moment.js,则可以轻松完成。

var start = moment("2018-03-10", "YYYY-MM-DD");
var end = moment("2018-03-15", "YYYY-MM-DD");

//Difference in number of days
moment.duration(start.diff(end)).asDays();

//Difference in number of weeks
moment.duration(start.diff(end)).asWeeks();

如果您想在天数(忽略时间)内找到给定日期和当前日期之间的差异,请务必从当前日期的当前对象中删除时间,如下所示

moment().startOf('day')

查找给定日期和当前日期之间的天数差异

var given = moment("2018-03-10", "YYYY-MM-DD");
var current = moment().startOf('day');

//Difference in number of days
moment.duration(given.diff(current)).asDays();

答案 2 :(得分:15)

尝试:

//Difference in days

var diff =  Math.floor(( start - end ) / 86400000);
alert(diff);

答案 3 :(得分:4)

尝试使用moment.js(在javascript中计算日期操作非常容易)

firstDate.diff(secondDate,'days',false); // true | false为分数值

结果将以整数形式给出天数。

答案 4 :(得分:1)

你也可以使用这段代码:moment(“yourDateHere”,“YYYY-MM-DD”)。fromNow()。这将计算今天和您提供的日期之间的差异。

答案 5 :(得分:1)

这对我有用:

const from = '2019-01-01';
const to   = '2019-01-08';

Math.abs(
    moment(from, 'YYYY-MM-DD')
      .startOf('day')
      .diff(moment(to, 'YYYY-MM-DD').startOf('day'), 'days')
  ) + 1
);

答案 6 :(得分:0)

我使用Moment.js在ES6中实现了快速可重用的功能。

const getDaysDiff = (start_date, end_date, date_format = 'YYYY-MM-DD') => {
  const getDateAsArray = (date) => {
    return moment(date.split(/\D+/), date_format);
  }
  return getDateAsArray(end_date).diff(getDateAsArray(start_date), 'days') + 1;
}

console.log(getDaysDiff('2019-10-01', '2019-10-30'));
console.log(getDaysDiff('2019/10/01', '2019/10/30'));
console.log(getDaysDiff('2019.10-01', '2019.10 30'));
console.log(getDaysDiff('2019 10 01', '2019 10 30'));
console.log(getDaysDiff('+++++2019!!/###10/$$01', '2019-10-30'));
console.log(getDaysDiff('2019-10-01-2019', '2019-10-30'));
console.log(getDaysDiff('10-01-2019', '10-30-2019', 'MM-DD-YYYY'));

console.log(getDaysDiff('10-01-2019', '10-30-2019'));
console.log(getDaysDiff('10-01-2019', '2019-10-30', 'MM-DD-YYYY'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.24.0/moment.js"></script>

答案 7 :(得分:-1)

MVC 我有两个输入文字 1:天数 2:日期时间选择器

 @Html.TextBox("HeaderINVID", null, new { @id = "HeaderINVID", @type = "number", @class = "form-control", autocomplete = "off", placeholder = "Day Count " })

  @Html.TextBox("HeaderINVDT", null, new { id = "HeaderINVDT", @class = "form-control format-picker", autocomplete = "off", placeholder = " Date" })

javascipt

从日期开始计算数字

    $("#HeaderINVID").bind("keyup", function (e) {
        var INVID = $("#HeaderINVID").val();
        var date = moment()
            .add(INVID, 'd')
            .toDate(); 
        $("#HeaderINVDT").val(moment(date).format('YYYY-MM-DD')) ;
    })

要计算两个日期之间的天数,请使用

  $("#HeaderINVDT").bind('change', function (e) {
        var StDT = moment($("#HeaderINVDT").val()).startOf('day');
        var NODT = moment().startOf('day');
        $("#HeaderINVID").val(StDT.diff(NODT, 'days'));
    })

不要忘记添加http://momentjs.com/