最近项目有这个一个需求,如下图所示
两个时间,一个是离开时间,一个是抵达(回来)的时间,选择离开时间,需要去判断,抵达时间有没有值,如果有值,那么离开时间必须小于抵达时间并且大于当前时间,如果抵达时间没有值,那么离开时间大于当前时间,当前之前的时间不能让用户选择;同理,抵达时间也是如此。
我们看下面的代码进行说明
<template>
<div>
<el-date-picker
v-model="filters.column.create_start_date"
type="date"
:picker-options="pickerBeginDateBefore"
format="yyyy-MM-dd"
placeholder="开始日期"
>
</el-date-picker>
<el-date-picker
v-model="filters.column.create_end_date"
type="date" format="yyyy-MM-dd"
:picker-options="pickerBeginDateAfter"
placeholder="结束日期"
>
</el-date-picker>
<input type="date">
</div>
</template>
<script>
export default {
name: "data",
data() {
return {
filters: {
column: {
create_start_date: '',
create_end_date: ''
},
},
pickerBeginDateBefore: {
disabledDate: (time) => {
if(this.filters.column.create_end_date === ''){
return time.getTime() < Date.now() - 8.64e7
}else {
let beginDateVal = this.filters.column.create_end_date;
if (beginDateVal) {
return time.getTime() > beginDateVal || time.getTime() < Date.now() - 8.64e7;
}
}
}
},
pickerBeginDateAfter: {
disabledDate: (time) => {
if(this.filters.column.create_start_date === ''){
this.flag = true
return time.getTime() < Date.now() - 8.64e7
}else {
let beginDateVal = this.filters.column.create_start_date;
if (beginDateVal) {
return time.getTime() < beginDateVal || time.getTime() < Date.now() - 8.64e7;
}
}
}
}
}
}
}
</script>
<style scoped>
</style>
我所想的是当用户选择离开时间的时候,判断抵达时间是否有值,如果有值,必须满足大于当前时间并且小于抵达的时间,这个时间段,所以我用的&&运算符,可是有问题,死活都不行,最终用了||运算符号,就合适了。自己也不知道是什么问题,就整下下,下次遇到尽量避免这种问题。如果有大佬知道,希望不吝赐教。