需求场景: 用于时间段内选择星期几重复
逻辑:计算从开始到结束中间有周几,然后判断有没有存在选中的周几
代码如下:
const judgeWeek1 = (startDate, endDate, weekList) => {
const start = new Date(startDate.replace(/-/ig, '/'))
const end = new Date(endDate.replace(/-/ig, '/'))
// 用毫秒值计算
if (end.getTime() - start.getTime() < 6 * 24 * 60 * 60 * 1000) {
const count = (end - start) / (24 * 60 * 60 * 1000) + 1
const arr = []
for (let i = 0; i < count; i++) {
// 获取从开始时间-结束时间中存在周几
arr.push(new Date(start.getTime() + i * 24 * 60 * 60 * 1000).getDay())
}
// 开始时间, 结束时间中间存在周几拼成的字符串
// 例如 2022-10-15-2022-10-16 是周六/周日 拼成 60
const str = arr.join('')
// 循环传入的数组,都存在str中说明全部满足
for (let k = 0; k < weekList.length; k++) {
if (str.indexOf(weekList[k]) === -1) {
return weekList[k]
}
}
}
// 开始时间-结束时间大于7天全部都有直接返回
return -1
}
// MON: 1,TUE: 2, WED: 3, THUR: 4, FRI: 5, SAT: 6, SUN: 0
// 传入开始时间2022-10-15 结束时间2022-10-16 周几的数组/周日,周六,周二
let week= judgeWeek1('2022-10-15', '2022-10-16', [0, 6, 2])
console.log(week) // 2-周二不满足
// 传入开始时间2022-10-15 结束时间2022-10-16 周几的数组/周六
let week= judgeWeek1('2022-10-15', '2022-10-16', [6])
console.log(week) // -1-全都满足