vue3:el-date-picker三十天改成第二十九天的23:59:59

问:

function disabledDateOrder(time) {

if (form.value.announceStartTime) {

return time.getTime() < Date.parse(form.value.announceStartTime) || time.getTime() > Date.parse(form.value.announceStartTime) + 86400000 * 30

} else {

return false

}

}

这是我现在的代码,选择时间的时候从今天的凌晨0:0:0可以选择到一个月后的今天的0:0:0但是会提示已经超过三十天,我想要限制在今天选择到一个月后的今天的前一天的23:59:59怎么限制

回答:

您当前的代码逻辑是:

time.getTime() < Date.parse(form.value.announceStartTime) ||

time.getTime() > Date.parse(form.value.announceStartTime) + 86400000 * 30

这个逻辑限制的是:**从 `announceStartTime` 开始,最多 30 天后**,但这个"30天后"是精确到 **00:00:00** 的,所以您选择 **第30天的任何时间(如 23:59:59)** 都会超出这个限制,从而被禁用。

✅ 您的需求

选择时间范围:从 `announceStartTime` 的 **00:00:00** 到 **30天后的前一天的 23:59:59**

即:

起始时间:`2025-04-01 00:00:00`

结束时间:`2025-04-30 23:59:59`(而不是 `2025-05-01 00:00:00`)

✅ 正确做法:结束时间应为 `+ 86400000 * 29 + 86399999`

解释:

`86400000` = 1天(24小时)的毫秒数

`29 * 86400000` = 29天

再加上 `86399999` 毫秒(即 23小时59分59秒)= 第30天的 **23:59:59**

✅ 修改后的代码

function disabledDateOrder(time) {

if (form.value.announceStartTime) {

const startTime = Date.parse(form.value.announceStartTime); // announceStartTime 的 00:00:00 时间戳

const endTime = startTime + 86400000 * 29 + 86399999; // 29天 + 23:59:59

return time.getTime() < startTime || time.getTime() > endTime;

} else {

return false;

}

}

🔍 举例说明

假设 `announceStartTime = '2025-04-01'`

`startTime = 2025-04-01 00:00:00`(时间戳)

`endTime = 2025-04-01 + 29天 + 23:59:59 = 2025-04-30 23:59:59`

✅ 允许选择:

`2025-04-01 00:00:00` ✅

`2025-04-30 23:59:59` ✅

❌ 禁止选择:

`2025-04-30 23:59:59` 之后的任何时间 ❌

`2025-05-01 00:00:00` ❌

✅ 可选优化:更清晰的写法(使用日期对象)

function disabledDateOrder(time) {

if (!form.value.announceStartTime) return false;

const start = new Date(form.value.announceStartTime);

start.setHours(0, 0, 0, 0); // 确保是 00:00:00

const end = new Date(start);

end.setDate(end.getDate() + 29);

end.setHours(23, 59, 59, 999); // 设置为第30天的 23:59:59.999

const currentTime = time.getTime();

return currentTime < start.getTime() || currentTime > end.getTime();

}

这种方式更直观,不易出错。

✅ 总结

您原来的问题是:**`+ 86400000 * 30` 限制到了第30天的 00:00:00,而不是第30天的结束时间**。

✅ 正确做法是:

const endTime = startTime + 86400000 * 29 + 86399999;

或使用 `Date` 对象设置 `23:59:59`。

这样就能实现"从当天 00:00:00 到 30天内的最后时刻(即第29天结束)"的精确限制。

如有其他时间限制需求,欢迎继续提问!

相关推荐
炫饭第一名2 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫2 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊2 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter2 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折3 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_3 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码13 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial3 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu3 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端
jiayu3 小时前
Angular6学习笔记13:HTTP(3)
前端