elementUI日期选择器,选择日期各种范围禁用

之前找到了很多帖子推荐picker-options这个api,但现在好像已经用不了了.

用了disabled-date和calendar-change结合.

1.如果只是禁用当前日期前后只需要disabled-date

 

  <el-date-picker
    v-model="createTime"
    :disabled-date="disabledDateFn"
    value-format="YYYY-MM-DD HH:mm:ss"
    start-placeholder="开始时间"
    end-placeholder="结束时间" />
let disabledDateFn = (time: any) => {
 return time.getTime() < Date.now() - 60 * 60 * 24 * 1000; //禁止选择今天以前的日期
  // return time.getTime() > Date.now(); //禁止选择今天以后的日期
  // 禁用今天起前三天&后三天
  // const now = new Date();
  // const day = 60 * 60 * 24 * 1000;
  // return now > time.getTime() + 4 * day || now < time.getTime() - 3 * day;
};

2.如果要禁用选择日期后的固定日期范围,则用了disabled-date和calendar-change结合.

 

  <el-date-picker
    v-model="createTime"
    :disabled-date="disabledDateFn"
    type="datetimerange"
    range-separator="~"
    @change="changeFn"
    :default-time="defaultTime"
    @calendar-change="calendarChangeFn"
    value-format="YYYY-MM-DD HH:mm:ss"
    start-placeholder="开始时间"
    end-placeholder="结束时间" />
import { ref } from "vue";
let createTime = ref("");
let startTime = ref("");
let defaultTime = ref([new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)]);
let disabledDateFn = (time: any) => {
  // 禁用选中日期起前三后三天
  if (startTime.value) {
    const day = 60 * 60 * 24 * 1000;
    return (
      time.getTime() > startTime.value.getTime() + 3 * day ||
      time.getTime() < startTime.value.getTime() - 3 * day
    );
  }
};
const changeFn = (val: any) => {
  if (!val) {
    startTime.value = "";
  }
};
// 如果用户没有选择日期,那默认展示当前日的月份.选中日历日期后会执行回调,只有datetimerange才生效
const calendarChangeFn = (time: any) => {
  startTime.value = time[0];
  if (time[1]) {
    // 选完时间后解禁时间范围
    startTime.value = "";
  }
};

完整代码如下:

<template>
  <el-date-picker
    v-model="createTime"
    :disabled-date="disabledDateFn"
    type="datetimerange"
    range-separator="~"
    @change="changeFn"
    :default-time="defaultTime"
    @calendar-change="calendarChangeFn"
    value-format="YYYY-MM-DD HH:mm:ss"
    start-placeholder="开始时间"
    end-placeholder="结束时间" />
</template>
<script setup lang="ts">
import { ref } from "vue";
let createTime = ref("");
let startTime = ref("");
let defaultTime = ref([new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)]);
let disabledDateFn = (time: any) => {
  // return time.getTime() < Date.now() - 60 * 60 * 24 * 1000; //禁止选择今天以前的日期
  // return time.getTime() > Date.now(); //禁止选择今天以后的日期
  // 禁用今天起前三天&后三天
  // const now = new Date();
  // const day = 60 * 60 * 24 * 1000;
  // return now > time.getTime() + 4 * day || now < time.getTime() - 3 * day;
  // 禁用选中日期起前三后三天
  if (startTime.value) {
    const day = 60 * 60 * 24 * 1000;
    return (
      time.getTime() > startTime.value.getTime() + 3 * day ||
      time.getTime() < startTime.value.getTime() - 3 * day
    );
  }
};
const changeFn = (val: any) => {
  if (!val) {
    startTime.value = "";
  }
};
// 如果用户没有选择日期,那默认展示当前日的月份.选中日历日期后会执行回调,只有datetimerange才生效
const calendarChangeFn = (time: any) => {
  startTime.value = time[0];
  if (time[1]) {
    // 选完时间后解禁时间范围
    startTime.value = "";
  }
};
</script>

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值