vue3ElementPlus使两个日期联动控制(限制结束时间为开始时间的一个月)

vue3ElementPlus两个日期联动控制(限制结束时间为开始时间的一个月)

  • 代码展示
javascript 复制代码
<template>
  <div>
    <el-date-picker
      v-model="startDate"
      type="date"
      placeholder="选择开始日期"
      @change="handleStartChange"
    ></el-date-picker>
    
    <el-date-picker
      v-model="endDate"
      type="date"
      placeholder="选择结束日期"
      :disabled-date="disabledEndDate"
    ></el-date-picker>
  </div>
</template>

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

const startDate = ref(null)
const endDate = ref(null)

// 限制结束日期为开始日期加一个月
const disabledEndDate = (date) => {
  if (startDate.value) {
    const maxEndDate = new Date(startDate.value)
    maxEndDate.setMonth(maxEndDate.getMonth() + 1)
    return date < startDate.value || date > maxEndDate
  }
  return false // 开始日期未选择时,不限制结束日期
}

// 处理开始日期变化
const handleStartChange = (value) => {
  // 更新结束日期,确保在范围内
  if (endDate.value && (endDate.value < value || endDate.value > new Date(value).setMonth(new Date(value).getMonth() + 1))) {
    endDate.value = null
  }
}
</script>

代码说明

  • 开始日期选择器: 用户可以任意选择开始日期。
  • 结束日期选择器: 使用 disabled-date 属性,确保结束日期只能选择在开始日期之后,并且不超过一个月的限制。
  • 日期变化处理: 当开始日期变化时,检查当前结束日期是否在允许的范围内,如果不在则重置结束日期。

额外提示

确保在你的项目中已经安装并引入了 Element Plus 组件库,以使日期选择器正常工作。

相关推荐
用户841794814564 分钟前
vxe-gantt vue table 甘特图子任务多层级自定义模板用法
vue.js
还算善良_7 分钟前
【Vue】vue3实现文件预览组件(预览服务使用kkfileview)
javascript·vue.js·ecmascript
tangdou3690986558 分钟前
AI真好玩系列-Three.js手势控制游戏开发教程 | Interactive Game Development with Three.js Hand Con
前端·人工智能·ai编程
七夜zippoe10 分钟前
基于ReAct框架的智能体构建实战 - 从原理到企业级应用
前端·javascript·react.js·llm·agent·react
qinyuan1511 分钟前
使用husky和fabric规范git提交的注释
前端·后端
T___T12 分钟前
偷看浏览器后台,发现它比我忙多了
前端·浏览器
alamhubb12 分钟前
vue也支持声明式UI了,向移动端kotlin,swift看齐,抛弃html,pug升级版,进来看看新语法吧
前端·javascript·前端框架
毕设源码-邱学长13 分钟前
【开题答辩全过程】以 基于web的心理测评系统的设计与实现为例,包含答辩的问题和答案
前端
北辰alk14 分钟前
从零构建Vue项目的完全指南:手把手打造现代化前端工程
vue.js
Composure15 分钟前
在 UmiJS + Vue 3 项目中实现 WebP 图片自动转换和优化
前端·javascript