计算工作日 Jquery

Calculate Business Days Jquery

我正在使用 jquery 和 moment js 来计算工作日。由于一些奇怪的原因,2022 年 12 月 31 日是星期六,但我的代码仍将其显示为工作日。我的开始日期为 2022 年 12 月 30 日和 1(一)个 workDaysToAdd 日期为 2022 年 12 月 31 日星期六,这不是工作日。我的代码没有跳过 2022 年 12 月 31 日星期六。

function AddBusinessDays(startDate, workDaysToAdd) {
    var curDate = new Date(startDate);
    var realDaysToAdd = 0;
    while (workDaysToAdd > 0) {
        realDaysToAdd++;
        if (IsWorkDay(curDate)) {
            workDaysToAdd--;
        }
        curDate.setDate(curDate.getDate() + 1);
    }
    return realDaysToAdd;
}

function IsWorkDay(date) {
    var curDate = new Date(date);
    var dayOfWeek = curDate.getDay();
    var isWorkDay;
    if (dayOfWeek == 0 || dayOfWeek == 6) {
        isWorkDay = false;
    }
    else {
        isWorkDay = !isNationalDay(curDate);
    }
    return isWorkDay;
}

function isNationalDay(date) {
    var thisDate = new Date(date);
    var thisMoment = moment(thisDate);
    var holiday = thisMoment.holiday();
    var isHoliday = holiday != 'undefined' && holiday != null && holiday.length > 0;
    return isHoliday;
}

你的逻辑不正确。您从星期五开始并检查它是否是工作日(是)并递减 workDaysToAdd。如果开始时是 1,现在是 0 并且您的 while 循环退出。

将您的日期增量移动到循环的顶部,以便您检查天。

function AddBusinessDays(startDate, workDaysToAdd) {
  const curDate = new Date(startDate);
  let realDaysToAdd = 0;
  while (workDaysToAdd > 0) {
    curDate.setDate(curDate.getDate() + 1); // move this to the top of the loop
    realDaysToAdd++;
    if (IsWorkDay(curDate)) {
      workDaysToAdd--;
    }
  }
  return realDaysToAdd;
}

function IsWorkDay(date) {
  return date.getDay() % 6 && !isNationalDay(date);
}

function isNationalDay(date) {
  return false; // no idea where the moment.holiday() comes from
}

const startDate = new Date(Date.UTC(2022, 11, 30));
console.log("start", startDate);
console.info(AddBusinessDays(startDate, 1))