element ui 时间日期选择器限制时间

需求

  • 跨天时间日期选择器限制到日
  • 开始时间结束时间为同一天限制到小时

实现 

  1. 使用type="datetimerange"来实现
  2. html
     <el-date-picker
              v-model="dateRange"
              value-format="yyyy-MM-dd HH"
              format="yyyy-MM-dd HH"
              type="datetimerange"
              popper-class="not-day"
              :picker-options="pickerOptions"
              range-separator="-"
              start-placeholder="开始时间"
              end-placeholder="结束时间"
              clearable
            ></el-date-picker>

 3.通过picker-options属性来控制时间可选日期范围

 data() {
    var _this = this
    return {
      pickerOptions: {
        disabledDate(time) {
          return time.getTime() >= Date.now()
        },
        onPick({ maxDate, minDate }){
          if(moment(minDate).format("YYYY-MM-DD")!=moment(maxDate).format("YYYY-MM-DD")){
            let div = document.getElementsByClassName("not-day");
            let wrap = div[0].querySelectorAll(".el-date-range-picker__time-picker-wrap");
            wrap.forEach((item,index)=>{
              if((index+1)%2==0){
                let editor =  item.querySelector(".el-date-range-picker__editor");
                setTimeout(()=>{
                  editor.className = 'el-date-range-picker__editor el-input el-input--small is-disabled';
                },100)
              }
            })
          }else{
            _this.isDay = true
          }
        }
      }
    }
  },

css

.el-date-range-picker__editor.is-disabled,.el-date-range-picker__editor.is-disabled .el-input__inner{
  pointer-events: none;
}

其中用到的时间格式化方法monent.js

import moment from 'moment'

效果

跨日期截图

同一天截图

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值