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 组件库,以使日期选择器正常工作。

相关推荐
烛阴19 小时前
为什么 `Promise.then` 总比 `setTimeout(..., 0)` 快?微任务的秘密
前端·javascript·typescript
XiaoSong19 小时前
基于 React Native/Expo 项目的持续集成(CI)最佳实践配置指南
前端·react native·react.js
white-persist19 小时前
汇编代码详细解释:汇编语言如何转化为对应的C语言,怎么转化为对应的C代码?
java·c语言·前端·网络·汇编·安全·网络安全
张愚歌19 小时前
轻松打造个性化Leaflet地图标记
前端·javascript
华仔啊19 小时前
CSS实现高级流光按钮动画,这几行代码堪称神来之笔
前端·css
用户37779672109619 小时前
新值依赖旧值?并发更新的“坑”
javascript
歪歪10019 小时前
详细介绍一下“集中同步+分布式入库”方案的具体实现步骤
开发语言·前端·分布式·后端·信息可视化
林太白19 小时前
rust17-部门管理模块
前端·后端·rust
_处女座程序员的日常19 小时前
如何预览常见格式word、excel、ppt、图片等格式的文档
前端·javascript·word·excel·开源软件
明月与玄武19 小时前
前端文件上传终极指南:从原理到架构实践!
前端·前端文件上传终极指南