Рассчитать рабочие дни в месяце с Javascript - PullRequest
1 голос
/ 08 марта 2012

Я пытаюсь сделать 2 вещи.

  1. Рассчитать количество рабочих дней до даты в данном месяце на основе текущего дня (т. Е. Сегодня 7 марта 2012 г., следовательно, прошло 5 рабочих дней)
  2. Рассчитать количество рабочих дней в данном месяце на основе текущего дня (т. Е. Сегодня 7 марта 2012 г., поэтому в этом месяце осталось 17 рабочих дней.

Любая помощь здесь будет высоко ценится.

EDIT: Это то, что я пробовал до сих пор:

function isWeekday(year, month, day) {var day = new Date(year, month, day).getDay();return day !=0 && day !=6;}
function getWeekdaysInMonth(month, year) {var days = daysInMonth(month, year);var weekdays = 0;for(var i=0; i< days; i++) {if (isWeekday(year, month, i+1)) weekdays++;}return weekdays;}
function calcBusinessDays(dDate1, dDate2) {
    var iWeeks, iDateDiff, iAdjust = 0;
    if (dDate2 < dDate1) return -1;                 // error code if dates transposed
    var iWeekday1 = dDate1.getDay();                // day of week
    var iWeekday2 = dDate2.getDay();
    iWeekday1 = (iWeekday1 == 0) ? 7 : iWeekday1;   // change Sunday from 0 to 7
    iWeekday2 = (iWeekday2 == 0) ? 7 : iWeekday2;
    if ((iWeekday1 > 5) && (iWeekday2 > 5)) iAdjust = 1;  // adjustment if both days on weekend
    iWeekday1 = (iWeekday1 > 5) ? 5 : iWeekday1;    // only count weekdays
    iWeekday2 = (iWeekday2 > 5) ? 5 : iWeekday2;
    // calculate differnece in weeks (1000mS * 60sec * 60min * 24hrs * 7 days = 604800000)
    iWeeks = Math.floor((dDate2.getTime() - dDate1.getTime()) / 604800000)
    if (iWeekday1 <= iWeekday2) {
    iDateDiff = (iWeeks * 5) + (iWeekday2 - iWeekday1)
    } else {
    iDateDiff = ((iWeeks + 1) * 5) - (iWeekday1 - iWeekday2)
    }
    iDateDiff -= iAdjust                            // take into account both days on weekend
    return (iDateDiff + 1);                         // add 1 because dates are inclusive
}

Не совсем уверен, как соединить все это, чтобы рабочие дни прошли и рабочие дни ушли.

1 Ответ

1 голос
/ 08 марта 2012

Вот действительно простая функция, которая циклически повторяется в течение нескольких дней, должна быть достаточно быстрой, поскольку она никогда не должна повторяться более 31 раза. Если текущий день является рабочим днем, он учитывается в прошедших днях:

function businessDays(date) {

  // Copy date
  var t = new Date(date);
  // Remember the month number
  var m = date.getMonth();
  var d = date.getDate();
  var daysPast = 0, daysToGo = 0;
  var day;

  // Count past days
  while  (t.getMonth() == m) {
    day = t.getDay();
    daysPast += (day == 0 || day == 6)? 0 : 1;
    t.setDate(--d);
  }

  // Reset and count days to come
  t = new Date(date);
  t.setDate(t.getDate() + 1);
  d = t.getDate();

  while  (t.getMonth() == m) {
    day = t.getDay();
    daysToGo += (day == 0 || day == 6)? 0 : 1;
    t.setDate(++d);
  }
  return [daysPast, daysToGo];
}

alert(businessDays(new Date(2012,2,7))); // 7-Mar-2012 => 5, 17
...