需求场景复现(需要安装dayjs插件):
- 使用时间范围组件
el-date-picker其type="daterange" - 时间组件的选择下拉框展开时,时间可以任意选择.
- 用户点击了第一次,出现选择范围,目前是一个月(也就是当前选中的日期,前后一个月之内都是可选的,大于或小于时间范围的都不可选中)
- 如果用户第二次点开,时间范围不可选的限制要取消
// 平常使用的版本
// 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"
type="daterange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
format="yyyy-MM-dd"
value-format="yyyy-MM-dd"
class="w-220"
:picker-options="pickerOptions"
@focus="focusClearRange"
>
</el-date-picker>
// JS部分
// data区域
pickerOptions: {
disabledDate: time => {
if (this.pickerMinDate) {
return this.updatedPickerOptions(time)
}
},
onPick: tim => {
this.handlePickerDate = new Date(tim.minDate).getTime()
}
},
// methods
focusClearRange () {
this.handlePickerDate = ''
},
updatedPickerOptions (time) {
let maxTime = dayjs(this.handlePickerDate ).add(1, 'month').valueOf()
let minTime = dayjs(this.handlePickerDate ).subtract(1, 'month').valueOf()
return time.getTime() > maxTime || time.getTime() < minTime
},
效果展示
-
第一次点开时

-
第一次点击之后,动态计算可选范围

-
选中之后再次打开选择时间时

-
再次选择时,就会重复步骤一

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





