我们是开始时间选择先选的话,结束时间就只能选择当前天和后一天,如图
如果先选择结束时间,那么开始时间就只能选择当天和前一天,如图
代码
<el-date-picker
v-model="startTime"
type="datetime"
placeholder="开始日期"
value-format="yyyy-MM-dd HH:hh:ss"
:picker-options="pickerOptionsStart"
:clearable="false"
popper-class="monitoring_range_box"
/>
~
<el-date-picker
v-model="endTime"
type="datetime"
placeholder="结束日期"
:clearable="false"
value-format="yyyy-MM-dd HH:hh:ss"
popper-class="monitoring_range_box"
:picker-options="pickerOptionsEnd"
/>
// data里面写
pickerOptionsEnd: {
// 结束限制日期
disabledDate: this.disabledDateEnd
},
pickerOptionsStart: {
// 开始限制日期
disabledDate: this.disabledDateStart
}
methods里面
// 结束日期禁用选项
disabledDateEnd(time) {
const currentTime = moment(time).valueOf(); //每一天
const nextDay = moment(this.selectTime)
.add(1, "d")
.valueOf(); // 22号
return currentTime < this.selectTime || currentTime > nextDay;
},
// 开始日期禁用选项
disabledDateStart(time) {
if (this.selectTime2 != "") {
const currentTime = moment(time).valueOf(); //每一天
const lastDay = moment(this.selectTime2)
.subtract(1, "d")
.valueOf(); // 20号
return currentTime < lastDay || currentTime > this.selectTime2;
}
}
监听
startTime(nv) {
this.status = 1;
this.selectTime = moment(moment(nv).format("YYYY-MM-DD")).valueOf();
},
endTime(nv) {
this.status = 2;
this.selectTime2 = moment(moment(nv).format("YYYY-MM-DD")).valueOf();
}