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;
}
相关推荐
REDcker4 分钟前
个人博客网站建设指南 Markdown资产化与静态站选型部署
前端·后端·博客·markdown·网站·资产·建站
zhangfeng113312 分钟前
小龙虾 wordbuddy 安装浏览器控制器 agent-browser npm install -g agent-browse
前端·人工智能·npm·node.js
徐小夕25 分钟前
100小时,我做了一款AI CAD建模软件,开源!
前端·vue.js·github
Bigger25 分钟前
因为看不懂小棉袄的画,我写了个 AI 程序帮我“翻译”她的世界
前端·人工智能·ai编程
送鱼的老默1 小时前
学习笔记--入门typescript直接案例开搞
前端·typescript
Prometheus1 小时前
从 XMLHttpRequest 到 fetch、ReadableStream、SSE、EventSource:前端流式通信完整梳理
前端
光影少年1 小时前
useEffect 完整理解:依赖数组、副作用清理、模拟生命周期
前端·react.js·程序员
之歆2 小时前
DAY_18深度解析:数据类型转换与运算符全攻略(上)
前端·javascript
大家的林语冰2 小时前
pnpm 11 发布,弃用 JSON 和 npm CLI,进化为纯 ES6 模块,新增 pnpm pack-app 等命令,供应链保护默认启用,要求 Node
前端·javascript·node.js
漓漾li2 小时前
每日面试题-前端2
前端·react.js·面试