elDatePicker动态限制选择特定日期范围

本文介绍了如何在Vue项目中,结合elDatePicker组件和dayjs库,实现动态限制用户选择特定日期范围的功能。当用户首次选择时,可选范围为当前日期的前后一个月;二次选择时,将解除之前的限制,允许任意日期选择。通过这种方式,可以灵活地控制日期选择的范围,如限制为一周、一天或一年等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求场景复现(需要安装dayjs插件):

  1. 使用时间范围组件el-date-pickertype="daterange"
  2. 时间组件的选择下拉框展开时,时间可以任意选择.
  3. 用户点击了第一次,出现选择范围,目前是一个月(也就是当前选中的日期,前后一个月之内都是可选的,大于或小于时间范围的都不可选中)
  4. 如果用户第二次点开,时间范围不可选的限制要取消
// 平常使用的版本
// html部分
<el-date-picker
   v-model="params.receiving_time"
   type="daterange"
   range-separator="至"
   start-placeholder="开始日期"
   end-placeholder="结束日期"
   format="yyyy-MM-dd"
   value-format="yyyy-MM-dd"
   class="w-220"
   :picker-options="pickerOptions"
 >
 </el-date-picker>
// js部分
pickerOptions: {
  disabledDate: time => {
    let beginDateVal = dayjs().valueOf()
    if (beginDateVal) {
      return time.getTime() > beginDateVal
    }
  }
}
// 更改之后的版本 - 动态限制时间选择范围版本
// HTML部分
<el-date-picker
  v-model="params.receiving_time"
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值