0
点赞
收藏
分享

微信扫一扫

el-date-picker只能选择两天时间,其它禁用

云上笔记 2022-04-14 阅读 100
vue.js

我们是开始时间选择先选的话,结束时间就只能选择当前天和后一天,如图
在这里插入图片描述在这里插入图片描述

如果先选择结束时间,那么开始时间就只能选择当天和前一天,如图
在这里插入图片描述在这里插入图片描述
代码

 <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();
    }
举报

相关推荐

0 条评论