Element el-date-picker 组件多个日期/时间相互限制

在使用ElementUI的日期选择器DatePicker时,可以通过picker-options属性来设置限制,例如确保开始时间在结束时间之前,且两者都小于当前时间。文章提供了示例代码,展示如何在开始时间、结束时间和发表时间之间设置相互约束。

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

介绍

在使用 elementDatePicker 日期选择器时;当有多个时间,并且相互存在着限制关系的时候,可以使用日期选择器里的 picker-options 属性,来进行限制。

使用场景

一: 开始时间与结束时间

当有两个时间:开始时间和结束时间;
他们的关系是: 如果有开始时间,那么结束时间必须大于开始时间并且小于当前时间。如果有结束时间,那么开始时间必须再结束时间及以前。
代码如下:

<template>
  <div>
    <el-form class="publish-form" :model="form" :rules="rules" label-position="top" :inline="true" ref="fromData" :show-message="false">
      <el-form-item prop="startTime" label="开始时间" class="way-form-box">
         <el-date-picker v-model="form.startTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsStart" placeholder="请选择时间">
         </el-date-picker>
       </el-form-item>
      <el-form-item prop="finishTime">
         <span slot="label">
          创作完成时间
            <span style="color: #999;">(示例:1990-01-01</span>
         </span>
         <el-date-picker v-model="form.finishTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsEnd" placeholder="请选择">
         </el-date-picker>
      </el-form-item>
    </el-form>
  </div>
</template>
<template>
  <div>
    <el-form class="publish-form" :model="formData" :rules="rules" label-position="top" :inline="true" ref="formDataRef" :show-message="false">
      <el-form-item prop="startTime" label="开始时间" class="way-form-box">
        <el-date-picker v-model="formData.startTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsStart" placeholder="请选择时间">
        </el-date-picker>
      </el-form-item>
      <el-form-item prop="finishTime">
        <span slot="label">
          完成时间
            <span style="color: #999;">(示例:1990-01-01</span>
        </span>
        <el-date-picker v-model="formData.finishTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsEnd" placeholder="请选择">
        </el-date-picker>
      </el-form-item>
    </el-form>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        // form 表单字段
        formData: {
          startTime: "", // 开始时间
          finishTime: "", // 结束时间
        },
        rules: {
   	  	  // 开始时间
          startTime: [
            {
              type: "string",
              required: false,
              message: "请选择开始时间",
              trigger: "change",
            },
          ],
          // 结束时间
          finishTime: [
            {
              type: "string",
              required: true,
              message: "请选择完成时间",
              trigger: "change",
            },
          ],
        },
        // 开始时间限制
        pickerOptionsStart: {
          disabledDate: time => {
            // 获取结束时间
            let endTime = this.formData.finishTime;
            // 如果有结束时间,开始时间必须在结束时间及以前
            if(endTime) {
              return (time.getTime() >= new Date(endTime).getTime());
            } else {
              // 选择今天之前
              // return time.getTime() > Date.now() - 8.64e6 - 24*60*60*1000;
              // 今天及以前
              return time.getTime() > Date.now() - 8.64e6;
            }
          }
        },
        // 结束时间限制
        pickerOptionsEnd: {
          disabledDate: time => {
            // 获取开始时间
            let startTime = this.formData.startTime;
            // 如果有开始时间,结束时间必须在开始时间及以后
            if(startTime) {
              // 选择开始时间以前
              // return ((time.getTime() < new Date(startTime).getTime() - 8.64e6)  || ( time.getTime() > Date.now() - 8.64e6));
              //  开始时间及以前
              return ((time.getTime() <= new Date(startTime).getTime() - 86400000) || (time.getTime() >= Date.now()));
            }
          }
        }
      }
    }
  }
</script>

二: 开始时间,结束时间与发表时间

当有三个时间:开始时间和结束时间,发表时间;
他们的关系是: 开始时间 <= 结束时间 <= 发表时间
代码如下:

<template>
  <div>
    <el-form class="publish-form" :model="formData" :rules="rules" label-position="top" :inline="true" ref="formDataRef" :show-message="false">
      <el-form-item prop="startTime" label="开始时间" class="way-form-box">
        <el-date-picker v-model="formData.startTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsStart" placeholder="请选择时间">
        </el-date-picker>
      </el-form-item>
      <el-form-item prop="finishTime">
        <span slot="label">
          完成时间
            <span style="color: #999;">(示例:1990-01-01</span>
        </span>
        <el-date-picker v-model="formData.finishTime" value-format="yyyy-MM-dd" type="date" :picker-options="pickerOptionsEnd" placeholder="请选择">
        </el-date-picker>
      </el-form-item>
      <el-form-item prop="publishTime" label="发表时间">
        <el-date-picker v-model="formData.publishTime" value-format="yyyy-MM-dd" type="date" :picker-options="publishOptions" placeholder="请选择时间">
        </el-date-picker>
      </el-form-item>
    </el-form>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        // form 表单字段
        formData: {
          startTime: "", // 开始时间
          finishTime: "", // 结束时间
          publishTime: "", // 发表时间
        },
        rules: {
   	  	  // 开始时间
          startTime: [
            {
              type: "string",
              required: false,
              message: "请选择开始时间",
              trigger: "change",
            },
          ],
          // 结束时间
          finishTime: [
            {
              type: "string",
              required: true,
              message: "请选择完成时间",
              trigger: "change",
            },
          ],
        },
        // 开始时间限制
        pickerOptionsStart: {
          disabledDate: time => {
            // 获取结束时间
            let endTime = this.formData.finishTime;
             // 获取发表时间
            let publishTime = this.formData.publishTime;
            // 如果有结束时间,开始时间必须在结束时间及以前
            if (endTime) {
              return (time.getTime() >= new Date(endTime).getTime());
            }
            //  如果选择了发表时间;那么开始时间必须在发表以前
            if (publishTime) {
              return (time.getTime() >= new Date(publishTime).getTime());
            }
            else {
              //  console.log(Date.now());
              // 选择今天之前
              // return time.getTime() > Date.now() - 8.64e6 - 24*60*60*1000;
              // 今天及以前
              return time.getTime() > Date.now() - 8.64e6;
            }
          }
        },
        // 结束时间限制
        pickerOptionsEnd: {
          disabledDate: time => {
            // 获取开始时间
            let startTime = this.formData.startTime;
            // 获取发表时间
            let publishTime = this.formData.publishTime;
            if (startTime && publishTime) {
              // 如果有开始时间  并且有  发表时间;  那结束时间必须在开始及以后 ;并且 发表及以前
              return ((time.getTime() <= new Date(startTime).getTime() - 86400000) || (time.getTime() > new Date(publishTime).getTime()))
            } else if (startTime) {
              return ((time.getTime() <= new Date(startTime).getTime() - 86400000) || (time.getTime() >= Date.now()));
            }
            else if (publishTime) {
              return (time.getTime() >= new Date(publishTime).getTime());
            }
            else {
              // 选择今天以及今天之前
              return time.getTime() > Date.now() - 8.64e6;
            }
          }
        },
        // 发表时间
        publishOptions: {
          disabledDate: time => {
            // 获取完成时间
            let endTime = this.formData.finishTime;
            if (endTime) {
              return ((time.getTime() <= new Date(endTime).getTime() - 86400000) || (time.getTime() > Date.now()));
            } else {
              // 选择今天以及今天之前;
              return time.getTime() > Date.now() - 8.64e6;
            }
          }
        },
      }
    }
  }
</script>

### Element UI `el-date-picker` 组件 设置时间选择限制 为了实现特定的时间选择限制,比如只允许用户选择当前日期之后七天内的日期,在Element UI中的`el-date-picker`组件可以通过配置`picker-options`属性来达成这一目标。具体来说,通过定义`disabledDate`函数可以精确控制哪些日期是可以被选择的。 对于预计下单时间只能选择当前日期后7天的时间这种需求,可以在Vue实例的数据对象中定义一个名为`pickeroptions`的对象,该对象包含了一个用于禁用不符合条件日期的方法[^1]: ```javascript data() { return { form: { date6: '' }, pickeroptions: { disabledDate(time) { const today = new Date(); const sevenDaysLater = new Date(today); sevenDaysLater.setDate(sevenDaysLater.getDate() + 7); // 不可以选择早于今天的日期以及晚于今天加七天后的日期 return time.getTime() < today || time.getTime() > sevenDaysLater; } } }; } ``` 上述代码片段展示了如何利用JavaScript计算出未来第七日的具体时间戳,并将其作为比较标准之一;同不允许选择当天之前的任何一天。这样就实现了仅能选择从明天起至一周内任意一日的效果。 另外一种场景下,如果想要设定可选月份或更复杂的日期范围,则可以根据实际情况调整`disabledDate`逻辑并应用到相应的模板标签上[^2]。 当涉及到区间选择器,默认值和其他高级选项,也可以借助类似的思路去定制化满足不同业务逻辑的需求。例如设置初始的选择区间或者进一步细化不可选日期规则等操作都可以在此基础上扩展完成[^3]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值