element-ui中的时间插件坑

最近项目有这个一个需求,如下图所示


两个时间,一个是离开时间,一个是抵达(回来)的时间,选择离开时间,需要去判断,抵达时间有没有值,如果有值,那么离开时间必须小于抵达时间并且大于当前时间,如果抵达时间没有值,那么离开时间大于当前时间,当前之前的时间不能让用户选择;同理,抵达时间也是如此。

我们看下面的代码进行说明

<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>

我所想的是当用户选择离开时间的时候,判断抵达时间是否有值,如果有值,必须满足大于当前时间并且小于抵达的时间,这个时间段,所以我用的&&运算符,可是有问题,死活都不行,最终用了||运算符号,就合适了。自己也不知道是什么问题,就整下下,下次遇到尽量避免这种问题。如果有大佬知道,希望不吝赐教。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值