前言
最近,有这么个需求,给用户做个请假审批系统,要输入请假开始时间和结束时间,同时计算出请假天数,如果年假数量不够提示不能提交,如果年假数量够的话,就走审批工作流,审批通过以后,自动在年假上减去这个请假天数。
审批流程很简单,就是找自己的经理审批就好了,在SharePoint里创建一个简单的workflow就可以实现。但是请假天数着实花了点时间,用JavaScript实现了。下面,就把写完的JavaScript代码拿出来,大家给找找bug吧。
var ssdate = "2018-11-12";
var eedate = "2018-11-14";
console.log("从" + ssdate + "到" + eedate + "请假天数为" + getHoliday(ssdate, eedate));
function getHoliday(sdate, edate) {
var num = datedifference(sdate, edate);
var lastday = num % 7;
var weeknum = 0;
if (num >= 7) {
weeknum = parseInt(num / 7);
}
var weekday = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"];
var result = 0;
for (var i = 0; i < lastday; i++) {
var dd = new Date(addDate(sdate, i)).getDay();
if (weekday[dd] != "星期六" && weekday[dd] != "星期日") {
result++;
}
}
return result + weeknum * 5;
}
//两个时间相差天数 兼容firefox chrome
function datedifference(sDate1, sDate2) { //sDate1和sDate2是2006-12-18格式
var dateSpan, tempDate, iDays;
sDate1 = Date.parse(sDate1);
sDate2 = Date.parse(sDate2);
dateSpan = sDate2 - sDate1;
dateSpan = Math.abs(dateSpan);
iDays = Math.floor(dateSpan / (24 * 3600 * 1000));
return iDays
};
function addDate(date, days) {
var d = new Date(date);
d.setDate(d.getDate() + days);
var m = d.getMonth() + 1;
return d.getFullYear() + '-' + m + '-' + d.getDate();
}