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天结束)"的精确限制。

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

相关推荐
颜酱17 小时前
基于Antd的SchemaForm 的表单复杂配置
前端·javascript·ant design
专注VB编程开发20年17 小时前
vb.net COM DLL 示例,实现了所有 VB6 X86 数据类型的对应
开发语言·前端·vb.net·com·vb6·activex dll
要加油哦~17 小时前
vue 构建工具如何选择 | vue-cli 和 vite的区别
前端·javascript·vue.js
Restart-AHTCM17 小时前
ES6核心基础
vue.js·前端框架·es6
李剑一18 小时前
为了免受再来一刀的痛苦,我耗时两天开发了一款《提肛助手》
前端·vue.js·rust
红尘散仙18 小时前
使用 Tauri Plugin-Store 实现 Zustand 持久化与多窗口数据同步
前端·rust·electron
沙白猿18 小时前
npm启动项目报错“无法加载文件……”
前端·npm·node.js
tyro曹仓舒19 小时前
彻底讲透as const + keyof typeof
前端·typescript
徐小夕@趣谈前端19 小时前
pxcharts多维表格编辑器Ultra版:支持二开 + 本地化部署的多维表格解决方案
大数据·javascript·react.js·编辑器·开源软件·r-tree·多维表格
蛋黄液19 小时前
【黑马程序员】后端Web基础--Maven基础和基础知识
前端·log4j·maven