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

在这里插入图片描述

<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>
 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",
      },
    }
}
// 半年,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;
}

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-02-03 08:38:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-03 08:38:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-03 08:38:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-03 08:38:02       18 阅读

热门阅读

  1. python实现opencv(清华镜像)

    2024-02-03 08:38:02       32 阅读
  2. 计算机网络(第六版)复习提纲24

    2024-02-03 08:38:02       26 阅读
  3. Beats:在单个服务器上配置多个 Beats 实例

    2024-02-03 08:38:02       25 阅读
  4. RabbitMQ

    2024-02-03 08:38:02       26 阅读
  5. 100 个 NLP 面试问题

    2024-02-03 08:38:02       30 阅读
  6. Ubuntu开机自启redis

    2024-02-03 08:38:02       31 阅读