使用datetime-picker AngularJs计算所选日期和当前日期之间的天数

时间:2019-02-05 07:55:03

标签: angularjs datepicker bootstrap-4 angular-ui-bootstrap

我在angularjs中使用bootstrap datetime-picker

我使用这样的日期选择器的dateDisabled选项禁用了几天

        $scope.dateOptions = {
        dateFormat: 'yyyy-MM-dd',
        maxDate: new Date(2020, 5, 22),
        minDate: new Date(),
        startingDay: 1,
        onChangeDate: countDays,
        dateDisabled: function (data) {
            var date = new Date(data.date)
            date.setHours(0, 0, 0, 0)

            var date2 = new Date('2019-02-08')
            date2.setHours(0, 0, 0, 0)

            return (date == date2.toString());
        }
    };

现在需要根据日期选择器来计算所选日期与当前日期之间的天数,即,禁用日期不应计入天数计算中。

enter image description here

如果我将日期选择为2019年2月10日,则应将天数计为 4(使用当前日期-2019年2月5日)。

但它快到5

当我从日期选择器中选择日期时,该函数会调用

 function countDays(dateTime) {
     var fourDaysLater = new Date();

     fourDaysLater.setDate(dateTime.getDate() - 4);
    }

如何计算在日期选择器中启用的日期?

1 个答案:

答案 0 :(得分:0)

回答您的问题

  

如何计算在日期选择器中启用的日期?

您已经使用日期选择器禁用了日期,但是当您计算两个日期之间的天数时,您正在使用无法访问日期选择器日期的新date()。

您可以执行以下操作-

function countDays(dateTime) {

     // Current date
     var currentDate = new Date().setHours(0, 0, 0, 0);

     // Selected date
     var selectedDate = new Date(dateTime).setHours(0, 0, 0, 0);

     // Count working days between selected date and current date
     while (currentDate < selectedDate) {

            if (currentDate != new Date('2019-02-08').setHours(0, 0, 0, 0)) {
                ++workingDays;
            }
            currentDate.setDate(currentDate.getDate() + 1);
        }
    }

   alert(workingDays);  // Number of working days

计算两天之间的天数,并减去