前言
最近,有這麼個需求,給使用者做個請假審批系統,要輸入請假開始時間和結束時間,同時計算出請假天數,如果年假數量不夠提示不能提交,如果年假數量夠的話,就走審批工作流,審批通過以後,自動在年假上減去這個請假天數。
審批流程很簡單,就是找自己的經理審批就好了,在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(); }