【ElementUI】日期选择器时间选择范围限制

本文详细介绍ElementUI日期选择器的高级用法,包括限制日期范围、禁用特定日期及实现日期区间选择等功能,适用于Vue项目的日期筛选需求。

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

ElementUI是饿了么推出的一套基于vue2.x的一个ui框架。官方文档也很详细,这里做一个element-ui日期插件的补充。

  官方文档中使用picker-options属性来限制可选择的日期,这里举例子稍做补充。

  单个输入框的

  组件代码:

<el-date-picker
       v-model="value1"
       type="date"
       placeholder="选择日期"
       :picker-options="pickerOptions0">
</el-date-picker>

  情景1: 设置选择今天以及今天之后的日期

 

data (){
   return {
       pickerOptions0: {
          disabledDate(time) {
            return time.getTime() < Date.now() - 8.64e7;
          }
        },  
   }     
}    

 

  情景2: 设置选择今天以及今天以前的日期

 

data (){
   return {
       pickerOptions0: {
          disabledDate(time) {
            return time.getTime() > Date.now() - 8.64e6
          }
        },  
   }     
}   

 

  情景3: 设置选择今天之后的日期(不能选择当天时间)

 

data (){
   return {
       pickerOptions0: {
          disabledDate(time) {
            return time.getTime() < Date.now();
          }
        },  
   }     
}    

 

  情景4: 设置选择今天之前的日期(不能选择当天)

 

data (){
   return {
       pickerOptions0: {
          disabledDate(time) {
            return time.getTime() > Date.now();
          }
        },  
   }     
}    

 

  情景5: 设置选择三个月之前到今天的日期

 

data (){
   return {
       pickerOptions0: {
          disabledDate(time) {
            let curDate = (new Date()).getTime();
            let three = 90 * 24 * 3600 * 1000;
            let threeMonths = curDate - three;
            return time.getTime() > Date.now() || time.getTime() < threeMonths;;
          }
        },  
   }     
} 

 

  两个输入框

  组件代码

 

<el-date-picker
       v-model="value1"
       type="date"
       placeholder="开始日期"
       :picker-options="pickerOptions0">
</el-date-picker>
<el-date-picker
       v-model="value2"
       type="date"
       placeholder="结束日期"
       :picker-options="pickerOptions1">
</el-date-picker>

 

  情景1: 限制结束日期不能大于开始日期

 

data(){
    return {
         pickerOptions0: {
                disabledDate: (time) => {
                    if (this.value2 != "") {
                        return time.getTime() > Date.now() || time.getTime() > this.value2;
                    } else {
                        return time.getTime() > Date.now();
                    }

                }
            },
            pickerOptions1: {
                disabledDate: (time) => {
                    return time.getTime() < this.value1 || time.getTime() > Date.now();
                }
            },
    }      
}       

 

  针对选择范围(type="daterange")的日期筛选,类似于单个输入框的情况,直接使用参数time进行判断

来源

 

### ElementUI 日期时间选择限制可选范围 在使用 `ElementUI` 的 `DatePicker` 组件时,可以通过配置 `picker-options` 属性来实现对可选日期范围限制。具体来说,通过定义 `disabledDate` 函数可以动态决定哪些日期应该被禁用。 对于日期时间选择,在 HTML 中如下所示: ```html <el-form-item label="活动开始时间" prop="startTime"> <el-date-picker type="datetime" placeholder="请选择开始时间" style="width: 100%" clearable format="yyyy-MM-dd HH:mm:ss" :picker-options="pickerOptions" v-model="form.startTime"> </el-date-picker> </el-form-item> ``` 为了限制可以选择的具体时间段,可以在 Vue 实例的数据部分定义 `pickerOptions` 对象,并指定 `disabledDate` 方法用于判断某个给定日期是否应被禁用[^3]。 下面是一个具体的 JavaScript (Vue.js) 示例代码片段展示如何仅允许用户选择未来三天内的日期(含当天),并禁止过去日期以及超过三天后的日期选择: ```javascript data() { return { form: { startTime: '' }, pickerOptions: { disabledDate(time) { const now = new Date(); // 不得早于当前时刻不得晚于三日后同一时刻 let threeDaysLater = new Date(now); threeDaysLater.setDate(threeDaysLater.getDate() + 3); return time.getTime() < now || time.getTime() > threeDaysLater; } } }; } ``` 此方法利用了 JavaScript 的 `Date` 对象来进行时间和日期的操作比较,从而实现了灵活的时间区间控制功能[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值