计算工作日 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))
我正在使用 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))