前言
最近,有这么个需求,给用户做个请假审批系统,要输入请假开始时间和结束时间,同时计算出请假天数,如果年假数量不够提示不能提交,如果年假数量够的话,就走审批工作流,审批通过以后,自动在年假上减去这个请假天数。
审批流程很简单,就是找自己的经理审批就好了,在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(); }