Element-ui date-picker日期范围为一个月 ---------基于vue

博客介绍了在Vue中运用disabledDate设置日期组件禁选日期,禁选范围为一个月,超出当前日期之后的日期将被禁用,并给出了日期组件代码及用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

运用disabledDate设置禁选日期,范围为一个月, 超出禁用当前日期之后禁用
如图:
在这里插入图片描述
以下为日期组件代码:

<template>
  <el-date-picker v-model="exCheckDate" type="daterange" :picker-options="pickerOptions" class="datePickers"
    value-format="yyyy-MM-dd" @change="changeDatePicker(exCheckDate)" @focus="changeDatefocus" :editable="false"
    size='small' :style="{width:width+60+'px'}" start-placeholder="开始日期" end-placeholder="结束日期">
  </el-date-picker>
</template>
<script>
  export default {
    props: {
      value: {
        type: [Array],
        required: true,
        default: []
      },
      nowNum:{
        type: Number,
        default: 1
      }
    },
    data() {
      return {
        width: 150,
        exCheckDate: [],
        minDate: '',
        maxDate: '',
        pickerOptions: {
          onPick: ({
            maxDate,
            minDate
          }) => {
            this.maxDate = maxDate;
            this.minDate = minDate;
          },
          disabledDate: (date) => {
            let maxDate = this.maxDate;
            let minDate = this.minDate;
            let endTime = '';
            if (minDate) {
              let val = Date.now() - (new Date(this.minDate).valueOf() + 30 * 24 * 60 * 60 * 1000);
              if (val < 0) {
                endTime = Date.now() - this.nowNum * 24 * 60 * 60 * 1000
                // this.nowNum == 1时不包含当前日期, this.nowNum == 0时包含当前日期
              } else {
                endTime = (new Date(this.minDate).valueOf() + 30 * 24 * 60 * 60 * 1000);
              }
              if (minDate && maxDate) {
                return date && (date.valueOf() > endTime)
              }
              return date && (date.valueOf() > endTime || date.valueOf() < minDate.valueOf() - 30 * 24 * 60 * 60 *
                1000)
            } else {
              return date && (date.valueOf() > Date.now() - this.nowNum * 24 * 60 * 60 * 1000)
            }
          }
        },
      }
    },
    methods: {
      changeDatePicker() {
        if (!this.exCheckDate) {
          this.minDate = '';
          this.maxDate = '';
          return
        }
        this.$emit('input', this.exCheckDate);
        this.$emit('change', this.exCheckDate);
      },
      changeDatefocus() {
        this.exCheckDate = []
        this.minDate = '';
        this.maxDate = '';
      },
    },
  }

</script>

用法:

//组件引入
 import DatePicke from './DataPicker.vue'
//注册
components:{
      DatePicke
    },
<date-picke v-model="exCheckDate" @change="changeDate"></date-picke>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值