Vue3 + Element Plus 日期选择器:开始 / 结束时间,结束时间不超过今天

写一个完整可直接复制使用的示例,包含:

  • 开始时间 ≤ 结束时间
  • 结束时间 最大只能选今天
  • 禁用逻辑联动(选完开始时间后,结束时间不能早于开始时间)
  • 支持 date / daterange 两种常用场景

完整代码(推荐:两个独立日期选择器)

vue 复制代码
<template>
  <div class="date-picker-box" style="display: flex; gap: 20px; margin: 20px;">
    <!-- 开始时间 -->
    <el-date-picker
      v-model="startDate"
      type="date"
      placeholder="选择开始时间"
      :disabled-date="disabledStartDate"
      value-format="YYYY-MM-DD"
    />

    <!-- 结束时间 -->
    <el-date-picker
      v-model="endDate"
      type="date"
      placeholder="选择结束时间"
      :disabled-date="disabledEndDate"
      value-format="YYYY-MM-DD"
    />
  </div>
</template>

<script setup>
import { ref } from 'vue'

// 时间绑定
const startDate = ref('')
const endDate = ref('')

// 今天的日期(用于禁用未来日期)
const today = new Date()

// 【开始时间禁用逻辑】:不能选未来日期(可选,根据需求)
const disabledStartDate = (time) => {
  // return time.getTime() > today.getTime() // 开启则开始时间也不能超过今天
  return false // 关闭则开始时间可以选未来日期
}

// 【结束时间禁用逻辑】:核心!
// 1. 不能早于开始时间
// 2. 不能超过今天
const disabledEndDate = (time) => {
  const startTime = startDate.value ? new Date(startDate.value) : null
  
  // 条件1:小于开始时间 → 禁用
  if (startTime && time.getTime() < startTime.getTime()) {
    return true
  }
  
  // 条件2:大于今天 → 禁用
  return time.getTime() > today.getTime()
}
</script>

如果你用的是 范围选择器(daterange)

更简洁,一个控件搞定:

vue 复制代码
<template>
  <el-date-picker
    v-model="dateRange"
    type="daterange"
    range-separator="至"
    start-placeholder="开始时间"
    end-placeholder="结束时间"
    :disabled-date="disabledDate"
    value-format="YYYY-MM-DD"
  />
</template>

<script setup>
import { ref } from 'vue'
const dateRange = ref([])
const today = new Date()

// 范围选择器禁用:只能选今天及以前
const disabledDate = (time) => {
  return time.getTime() > today.getTime()
}
</script>

核心说明

  1. disabled-date

    Element Plus 提供的禁用日期函数,返回 true 则该日期不可选。

  2. 结束时间限制

    • time.getTime() > today.getTime() → 禁止选择今天以后的日期
    • 联动开始时间 → 禁止选择早于开始时间的日期
  3. 格式
    value-format="YYYY-MM-DD" 直接输出字符串格式,不用自己处理 Date 对象。


总结

  • 两个独立选择器:结束时间 ≤ 今天 ,且不早于开始时间
  • 范围选择器:直接限制整个区间不超过今天
  • 代码可直接复制到 Vue3 + Element Plus 项目中使用
相关推荐
摇滚侠13 小时前
01 基础语法 JavaScript 入门到精通全套教程
开发语言·javascript·ecmascript
云水一下13 小时前
CSS3从零基础到精通(一):前世今生与基础入门
前端·css3
顾凌陵14 小时前
CSRF&SSRF漏洞攻击的溯源分析与实战
前端·csrf
用户69190268133914 小时前
JS 初了解:从“网页玩具”到企业级语言的进化
javascript
月月大王的3D日记14 小时前
Three.js 材质篇(中):从兰伯特到PBR,一篇文章看懂五种光照材质
前端·javascript
且白14 小时前
leaflet切片变色、地图滤镜逻辑实现 colorfilter
前端·javascript
用户8876654266314 小时前
Linux 终端入门:新手必须掌握的常用命令和基本思路
前端·操作系统
丷丩14 小时前
MapLibre GL JS第30课:添加视频
javascript·音视频·gis·mapbox·maplibre gl js
techdashen14 小时前
拆开任意 Electron 应用:从 Windows 安装包到 Discord 的私有更新协议
javascript·windows·electron
用户1257585243614 小时前
Vue3 后台框架的网络请求怎么设计?看 XYGo Admin 三套 Axios 实例与拦截器方案
前端