将区间时间段拆分成以半小时为间隔的子区间

灰太狼 2022-03-02 02:00 323阅读 0赞

需求如下图,后台设置店铺营业时间后前端需将时间区间段划分为按半小时为间隔的数组用于展示

图片描述

  1. let openTime = ['11:00 - 12:00', '17:00 - 19:00', '21:00 - 23: 00'];
  2. let y = new Date().getFullYear();
  3. let m = new Date().getMonth()+1;
  4. let d = new Date().getDate();
  5. let start = [], end = []; //start起始时间数组,end结束时间数组
  6. for(let i=0,len=openTime.length;i<len;i++) { //将时间字符串转换成日期格式并存入开始时间数组和结束时间数组
  7. let [s, e] = openTime[i].split('-');
  8. start.push(new Date(y+'/'+m+'/'+d+' '+s));
  9. end.push(new Date(y+'/'+m+'/'+d+' '+e));
  10. }
  11. let list = [];
  12. function formatTime(time) { //时间为个位数则补零
  13. return time < 10 ? '0' + time : time;
  14. }
  15. for(let i=0,len=start.length;i<len;i++) {
  16. let len2 = (end[i].getTime() - start[i].getTime())/(30*60*1000); //计算各子区间以半小时为间隔拆分后的数组长度
  17. for(let j=0;j<len2;j++) {
  18. if(start[i].getTime()+30*60*1000<=end[i].getTime()) {
  19. //将各子区间日期按半小时递增转换为时间并存入list数组
  20. let ss = new Date(start[i].getTime()+30*60*1000*j), ee = new Date(start[i].getTime()+30*60*1000*(j+1));
  21. list.push([formatTime(ss.getHours())+':'+formatTime(ss.getMinutes()), formatTime(ee.getHours())+':'+formatTime(ee.getMinutes())]);
  22. }
  23. }
  24. }
  25. list = list.map(item => {
  26. return item.join('-');
  27. })

发表评论

表情:
评论列表 (有 0 条评论,323人围观)

还没有评论,来说两句吧...

相关阅读