element-plus中限制日期选择器中的开始日期

本文介绍了Vue2和Vue3中日期选择器组件禁用日期功能的不同实现方式。在Vue2中,使用`picker-options`属性结合`disabledDate`函数来禁用过去的一天;而在Vue3中,该属性被替换为直接使用`disabledDate`。示例代码展示了如何在两个版本的Vue中设置日期范围只能选择未来的时间。
摘要由CSDN通过智能技术生成

重点

vue2和vue3两者不同点就是:vue3中使用disabledDate这个属性,vue2使用picker-options 这个属性

一、vue2中实现

 <el-dialog title="发布" v-model="publishDialog" width="400px" append-to-body :destroy-on-close="true">
          <el-form :model="publishForm" :rules="rules" label-width="100px" ref="pubRef">
            <el-row>
              <el-col :span="24">
                <el-form-item label="发布时间:" prop="publishTime">
                  <el-date-picker
                      v-model="publishForm.publishTime"
                      type="daterange"
                      range-separator="-"
                      start-placeholder="开始日期"
                      end-placeholder="结束日期"
                     :picker-options="disabledDateFun"
                      clearable
                  />
                </el-form-item>
              </el-col>
            </el-row>
          </el-form>
          <div class="dialog-footer" style="text-align: right;">
            <el-button @click="cancel">取 消</el-button>
            <el-button type="primary" @click="submitPub">保 存</el-button>
          </div>
        </el-dialog>

<script>
	/**
		把上面的:disabledDate="disabledDateFun"   替换成:picker-options="disabledDateFun"
		//因为vue3中没有pick-options这个属性
	*/
	data() {
 	 return {
    disabledDateFun: {
      disabledDate(time) {
        return time.getTime() < Date.now() - 8.64e7;  //8.64e7 表示就是一天的时间
      }
    },
  }
}
</script>

二、vue3中实现

<template>
 <el-dialog title="发布" v-model="publishDialog" width="400px" append-to-body :destroy-on-close="true">
          <el-form :model="publishForm" :rules="rules" label-width="100px" ref="pubRef">
            <el-row>
              <el-col :span="24">
                <el-form-item label="发布时间:" prop="publishTime">
                  <el-date-picker
                      v-model="publishForm.publishTime"
                      type="daterange"
                      range-separator="-"
                      start-placeholder="开始日期"
                      end-placeholder="结束日期"
                      :disabledDate="disabledDateFun"
                      clearable
                  />
                </el-form-item>
              </el-col>
            </el-row>
          </el-form>
          <div class="dialog-footer" style="text-align: right;">
            <el-button @click="cancel">取 消</el-button>
            <el-button type="primary" @click="submitPub">保 存</el-button>
          </div>
        </el-dialog>
</template>        

<script setup>
	 //设置发布日期大于等于当前日期
    const disabledDateFun = (time) => {
      if (time.getTime() < new Date().getTime()) {
        return time.getTime() <= new Date().getTime() - 1 * 8.64e7; //时间范围必须是时间戳
      }
    };
</script>

三、效果图

在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值