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

相关推荐
森叶5 分钟前
Electron 实战:用 utilityProcess 开子进程,去端口化承载协议处理,并由主进程拦截渲染请求后统一中转
前端·javascript·electron
精益数智工坊11 分钟前
红牌作战是什么?红牌作战的实施步骤与核心要点
大数据·运维·前端·人工智能·精益工程
techdashen17 分钟前
Cloudflare HTML 解析器的十年演化史(一)
前端·html
ZC跨境爬虫25 分钟前
移动端爬虫工具Fiddler完整配置流程:PC+安卓模拟器全覆盖,零基础一次配置成功
android·前端·爬虫·测试工具·fiddler
GISer_Jing29 分钟前
前端视角:B端传统配置化现状与AI冲击趋势
前端·人工智能·ai编程
课灵_klhubs33 分钟前
课灵h5p-3D 模型 (3D Model)教程
前端·3d·课程设计·教程·课灵·h5p
倾颜42 分钟前
接入 MCP 之后,我如何让 Skill 稳定消费 Tool / Resource / Prompt
前端·next.js·mcp
小赵同学WoW42 分钟前
BroadCast Channel() 浏览器跨标签页通信的实现方式之一
前端·浏览器
\xin43 分钟前
pikachu自编exp,xss之盲打,过滤,htmlspecialchars,href,js
前端·xss
ZC跨境爬虫1 小时前
前端实战复盘:从零完成Apple中国大陆官网UI第一阶段全量静态复刻
前端·css·ui·html