elementUI中分开的时间日期选择组件,控制日期的禁用

javascript 复制代码
<el-date-picker v-model="query.startTime" type="datetime" :picker-options="startPickerOptions" format="yyyy-MM-dd HH时" popper-class="date-picker" placeholder="选择日期时间"></el-date-picker>
<el-date-picker v-model="query.endTime" type="datetime" :picker-options="endPickerOptions" format="yyyy-MM-dd HH时" popper-class="date-picker" placeholder="选择日期时间"> </el-date-picker>
javascript 复制代码
 data() {
   return {
   query: {
        startTime: "",
        endTime: "",
      },
      startPickerOptions: {
        disabledDate: (time) => {
          if (this.query.endTime) {
            // 根据结束时间,向前推5天
            let timeStart = getRequiresTime(
              new Date(this.query.endTime),
              "day",
              -5
            );
            this.startPickerOptions.selectableRange = "02:00:00 - 23:59:59";
            return (
              time.getTime() > new Date(this.query.endTime).getTime() ||
              time.getTime() < new Date(timeStart).getTime()
            );
          }
        },
        selectableRange: "00:00:00 - 23:59:59",
      },
      endPickerOptions: {
        disabledDate: (time) => {
          if (this.query.startTime) {
            // 根据开始时间,向后推5天
            let timeEnd = getRequiresTime(
              new Date(this.query.startTime),
              "day",
              5
            );
            this.endPickerOptions.selectableRange = "04:00:00 - 23:59:59";
            return (
              new Date(this.query.startTime).getTime() > time.getTime() ||
              time.getTime() > new Date(timeEnd).getTime()
            );
          }
        },
        selectableRange: "00:00:00 - 23:59:59",
      },
    }
}
javascript 复制代码
// 半年,1年,3年前后的时间获取
export function getRequiresTime(time, type = null, number = 0) {
  var nowdate = new Date(time);
  switch (type) {
    case "day": //取number天前、后的时间
      nowdate.setTime(nowdate.getTime() + (24 * 3600 * 1000) * number);
      var y = nowdate.getFullYear();
      var m = nowdate.getMonth() + 1;
      var d = nowdate.getDate();
      var retrundate = y + '-' + (m >= 10 ? m : '0' + m) + '-' + (d >= 10 ? d : '0' + d);
      break;
    case "week": //取number周前、后的时间
      var weekdate = new Date(nowdate + (7 * 24 * 3600 * 1000) * number);
      var y = weekdate.getFullYear();
      var m = weekdate.getMonth() + 1;
      var d = weekdate.getDate();
      var retrundate = y + '-' + (m >= 10 ? m : '0' + m) + '-' + (d >= 10 ? d : '0' + d);
      break;
    case "month": //取number月前、后的时间
      nowdate.setMonth(nowdate.getMonth() + number);
      var y = nowdate.getFullYear();
      var m = nowdate.getMonth() + 1;
      var d = nowdate.getDate();
      var retrundate = y + '-' + (m >= 10 ? m : '0' + m) + '-' + (d >= 10 ? d : '0' + d);
      break;
    case "year": //取number年前、后的时间
      nowdate.setFullYear(nowdate.getFullYear() + number);
      var y = nowdate.getFullYear();
      var m = nowdate.getMonth() + 1;
      var d = nowdate.getDate();
      var retrundate = y + '-' + (m >= 10 ? m : '0' + m) + '-' + (d >= 10 ? d : '0' + d);
      break;
    default: //取当前时间
      var y = nowdate.getFullYear();
      var m = nowdate.getMonth() + 1;
      var d = nowdate.getDate();
      var retrundate = y + '-' + (m >= 10 ? m : '0' + m) + '-' + (d >= 10 ? d : '0' + d);
  }
  return retrundate;
}
相关推荐
人工智能训练师9 小时前
Ubuntu22.04如何安装新版本的Node.js和npm
linux·运维·前端·人工智能·ubuntu·npm·node.js
Seveny079 小时前
pnpm相对于npm,yarn的优势
前端·npm·node.js
yddddddy10 小时前
css的基本知识
前端·css
昔人'10 小时前
css `lh`单位
前端·css
前端君10 小时前
实现最大异步并发执行队列
javascript
Nan_Shu_61411 小时前
Web前端面试题(2)
前端
知识分享小能手11 小时前
React学习教程,从入门到精通,React 组件核心语法知识点详解(类组件体系)(19)
前端·javascript·vue.js·学习·react.js·react·anti-design-vue
蚂蚁RichLab前端团队12 小时前
🚀🚀🚀 RichLab - 花呗前端团队招贤纳士 - 【转岗/内推/社招】
前端·javascript·人工智能
孩子 你要相信光13 小时前
css之一个元素可以同时应用多个动画效果
前端·css
萌萌哒草头将军13 小时前
Oxc 和 Rolldown Q4 更新计划速览!🚀🚀🚀
javascript·vue.js·vite