基于Vue3 + Element Plus实现的日期选择器

 更新时间:2026年03月24日 09:13:28   作者:还是大剑师兰特  
本文介绍了使用Vue3和ElementPlus实现日期选择器的方法,包括禁用逻辑联动、设定结束时间不能选今天、时间格式化等功能,通过示例代码展示了两种常用场景的实现方式,适用于直接复制使用,需要的朋友可以参考下

实现效果

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

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

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

<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)

更简洁,一个控件搞定:

<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>

核心说明

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

结束时间限制

  • time.getTime() > today.getTime() → 禁止选择今天以后的日期
  • 联动开始时间 → 禁止选择早于开始时间的日期

格式
value-format="YYYY-MM-DD" 直接输出字符串格式,不用自己处理 Date 对象。

总结

  • 两个独立选择器:结束时间 ≤ 今天,且不早于开始时间
  • 范围选择器:直接限制整个区间不超过今天
  • 代码可直接复制到 Vue3 + Element Plus 项目中使用

以上就是基于Vue3 + Element Plus实现的日期选择器的详细内容,更多关于Vue3 Element Plus日期选择器的资料请关注脚本之家其它相关文章!

相关文章

  • Vue浏览器缓存sessionStorage+localStorage+Cookie区别解析

    Vue浏览器缓存sessionStorage+localStorage+Cookie区别解析

    这篇文章主要介绍了Vue浏览器缓存sessionStorage+localStorage+Cookie区别解析,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • 详解在不使用ssr的情况下解决Vue单页面SEO问题

    详解在不使用ssr的情况下解决Vue单页面SEO问题

    这篇文章主要介绍了在不使用ssr的情况下解决Vue单页面SEO问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • 富文本编辑器vue2-editor实现全屏功能

    富文本编辑器vue2-editor实现全屏功能

    这篇文章主要介绍了富文本编辑器vue2-editor实现全屏功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-05-05
  • Pycharm中开发vue element项目时eslint的安装和使用步骤

    Pycharm中开发vue element项目时eslint的安装和使用步骤

    这篇文章主要介绍了Pycharm中开发vue element项目时eslint的安装和使用,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • Vue全局事件总线和订阅与发布使用案例分析讲解

    Vue全局事件总线和订阅与发布使用案例分析讲解

    在 vue 里我们可以通过全局事件总线来实现任意组件之间通信,它的原理是给 Vue 的原型对象上面添加一个属性。这样的话我所有组件的都可以访问到这个属性,然后可以通过这个属性来访问其他组件给这个属性上面绑定的一些方法,从而去传递数据
    2022-08-08
  • Vue项目中loading卡死的问题及解决方案

    Vue项目中loading卡死的问题及解决方案

    文章剖析Vue项目中loading卡死问题,揭示其本质为异步阻塞与响应式渲染冲突,提出分五层解决方案:nextTick强制刷新、任务分片/Worker解耦、组件封装、组合式API管理状态、性能优化与架构调整,强调需从UI、异步、计算等多维度优化
    2025-07-07
  • 详解如何使用webpack在vue项目中写jsx语法

    详解如何使用webpack在vue项目中写jsx语法

    本篇文章主要介绍了详解如何使用webpack在vue项目中写jsx语法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • Vuejs第八篇之Vuejs组件的定义实例解析

    Vuejs第八篇之Vuejs组件的定义实例解析

    这篇文章主要介绍了Vuejs第八篇之Vuejs组件的定义实例解析的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • Vue中的计算属性与监听属性

    Vue中的计算属性与监听属性

    这篇文章介绍了Vue中的计算属性与监听属性,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • vue3中组件传值的多种方法总结

    vue3中组件传值的多种方法总结

    学习过vue2的宝子们肯定知道,组件传值是vue项目开发过程中必不可少的功能场景,下面这篇文章主要给大家介绍了关于vue3中组件传值的多种方法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-01-01

最新评论