当前位置: 首页 > news >正文

vue3+elementPlus el-date-picker 自定义禁用状态hook 建立结束时间不能小于开始时间

背景:

elementPlus的el-date-picker中,相较于了element,升级了写法,
如果为每一个开始时间、结束时间设置禁用状态,在全局中会造成代码冗余。
所以在vue3中采用自定义hook的方式,实现代码复用。

1、实现如下效果:

开始时间:今天过后日期不可选,如p1所示;
结束时间:必须大于开始时间,精确到时分秒,如p2所示。

开始时间

结束时间

2、编写hook(useDisabledDate.ts)

export function useDisabledDate() {// 开始时间与结束时间,采用赋值的方式const forDisStartTime = ref()const forDisEndTime = ref()// 不可用的开始时间,如图1所示const disabledStartTime = (data: Date) => {return data.getTime() > new Date().getTime()}// 结束时间--日期const disabledEndTimeDate = (data: Date) => {if (forDisStartTime.value) {const hours = new Date(forDisStartTime.value).getHours(),seconds = new Date(forDisStartTime.value).getSeconds(),minutes = new Date(forDisStartTime.value).getMinutes()if (hours == 0 && minutes == 0 && seconds == 0) return data.getTime() < new Date(forDisStartTime.value).getTime() - 1000else return data.getTime() < new Date(forDisStartTime.value).getTime() - 8.64e7}}
// 结束时间--时const disabledEndTimeHours = () => {const hours = new Date(forDisStartTime.value as Date).getHours(),sY = new Date(forDisStartTime.value).getFullYear(),sM = new Date(forDisStartTime.value).getMonth(),sD = new Date(forDisStartTime.value).getDate(),eY = new Date(forDisEndTime.value).getFullYear(),eM = new Date(forDisEndTime.value).getMonth(),eD = new Date(forDisEndTime.value).getDate()const arrs = []if (sY == eY && sM == eM && sD == eD) {for (let i = 0; i < 24; i++) {if (hours <= i) continuearrs.push(i)}}return arrs}// 结束时间--分const disabledEndTimeMinutes = () => {const minutes = new Date(forDisStartTime.value as Date).getMinutes(),sY = new Date(forDisStartTime.value).getFullYear(),sM = new Date(forDisStartTime.value).getMonth(),sD = new Date(forDisStartTime.value).getDate(),eY = new Date(forDisEndTime.value).getFullYear(),eM = new Date(forDisEndTime.value).getMonth(),eD = new Date(forDisEndTime.value).getDate()const arrs = []if (sY == eY && sM == eM && sD == eD) {for (let i = 0; i < 60; i++) {if (minutes <= i) continuearrs.push(i)}}return arrs}// 结束时间--秒const disabledEndTimeSeconds = () => {const seconds = new Date(forDisStartTime.value).getSeconds(),sY = new Date(forDisStartTime.value).getFullYear(),sM = new Date(forDisStartTime.value).getMonth(),sD = new Date(forDisStartTime.value).getDate(),eY = new Date(forDisEndTime.value).getFullYear(),eM = new Date(forDisEndTime.value).getMonth(),eD = new Date(forDisEndTime.value).getDate()const arrs = []if (sY == eY && sM == eM && sD == eD) {for (let i = 0; i < 60; i++) {if (seconds <= i) continuearrs.push(i)}}return arrs}return {forDisStartTime,forDisEndTime,disabledStartTime,disabledEndTimeDate,disabledEndTimeHours,disabledEndTimeMinutes,disabledEndTimeSeconds}
}

3、在.vue文件中使用该hook

<script setup lang="ts">
// 引入
import { useDisabledDate } from '@/hooks/useDisabledDate'
const formItem = reactive({beginTime: '',endTime: ''
})
// #region disabled-date
const {forDisStartTime,forDisEndTime,disabledStartTime,disabledEndTimeDate,disabledEndTimeHours,disabledEndTimeMinutes,disabledEndTimeSeconds
} = useDisabledDate()
// 赋值开始时间
watch(() => formItem.beginTime,(newTime) => {forDisStartTime.value = newTime},{ immediate: true }
)
// 赋值结束时间
watch(() => formItem.endTime,(newTime) => {forDisEndTime.value = newTime},{ immediate: true }
)
// #endregion
</script>
http://www.gsyq.cn/news/28752.html

相关文章:

  • 【做题记录】贪心--提高组
  • 【为美好CTF献上祝福】 New Star 2025 逆向笔记
  • XXL-JOB(5)
  • Ramanujan Master Theorem
  • 【周记】2025.10.13~2025.10.19
  • C++案例 自定义数组
  • 20251023周四日记
  • ord() 函数
  • Redis中的分布式锁之SETNX底层实现
  • 2025家纺摄影公司推荐,南通鼎尚摄影专注产品视觉呈现
  • 求函数
  • Python---简易编程解决工作问题
  • MPK(Mirage Persistent Kernel)源码笔记(1)--- 基础原理
  • 背包dp(1)
  • 比赛题解 总结
  • 1019:浮点数向零舍入(分正负取整)
  • 创建 SQL Server 数据库【通用】
  • HNSW算法实战:用分层图索引替换k-NN暴力搜索
  • Spring Boot 自动配置之 TaskExecutor - 实践
  • 二分图/忆re.
  • 《IDEA 2025长效采用配置指南:有效期配置至2099年实战之JetBrains全家桶有效》​
  • 如何制作PDF文件目录? - 详解
  • todesk远程到被控Mac后能看到画面,鼠标键盘执行无反应
  • JAVA 排序用法
  • esp32-usb-jtag 调试踩坑
  • MySQLDay3
  • 飞牛OS通过docker部署SillyTavern酒馆
  • 深入解析:XML中的 CDATA mybaitis xml中的 <![CDATA[ xxxx ]]>
  • AI股票预测分析报告 - 2025年10月23日 20:26
  • 软件包管理