时间日期选择器组件进行日期和时间的禁用处理逻辑

在当前业务背景,开始时间是不能小于当前时间的,结束时间是不能小于开始时间的,上面的时分秒同理。

同一天下,结束时间的时分秒不能小于开始时间

不同一天,结束时间没有限制

选择开始时间后,动态清空结束时间

开始时间选择器禁用配置

java 复制代码
<el-date-picker
  v-model="startForm.startTime"
  type="datetime"
  :disabled-date="disabledDate"
  :disabled-hours="disabledHours"
  :disabled-minutes="disabledMinutes"
/>

禁用过去的日期

**- 逻辑 :通过比较日期时间戳,禁用所有早于当前日期的日期

  • 参数 : date - 日期选择器中当前被点击的日期对象
  • 返回值 : true (禁用)/ false (可用)**
java 复制代码
function disabledDate(date) {
  // 禁止选择今天之前的日期
  return date.getTime() < Date.now() - 8.64e7; // 8.64e7 = 24*60*60*1000 毫秒
}

禁用过去小时

**- 逻辑 :获取当前系统小时数,禁用所有小于当前小时的小时选项

  • 返回值 :禁用的小时数组(如 [0,1,2,...,13] )**
java 复制代码
const disabledHours = () => {
  const currentHour = new Date().getHours();
  // 返回当前小时之前的所有小时数组(例如当前14点,则禁用0-13点)
  return Array.from({ length: currentHour }, (_, i) => i);
}

禁用过去分钟

**- 逻辑 :获取当前系统分钟数,禁用所有小于当前分钟的分钟选项

  • 返回值 :禁用的分钟数组(如 [0,1,2,...,29] )**
java 复制代码
onst disabledMinutes = () => {
  const currentMinute = new Date().getMinutes();
  // 返回当前分钟之前的所有分钟数组(例如当前30分,则禁用0-29分)
  return Array.from({ length: currentMinute }, (_, i) => i);
}

结束时间日期选择器配置

java 复制代码
<el-date-picker
  v-model="startForm.endTime"
  type="datetime"
  :disabled-date="disabledEndDate"
  :disabled-hours="disabledEndHours"
  :disabled-minutes="disabledEndMinutes"
  :default-time="defaultTime()"
/>

结束日期不能早于开始日期

java 复制代码
function disabledEndDate(date) {
  if (!startForm.value.startTime) return false;
  const startDate = new Date(startForm.value.startTime);
  // 仅比较年月日,忽略时间部分
  const dateYear = date.getFullYear();
  const dateMonth = date.getMonth();
  const dateDay = date.getDate();
  const startYear = startDate.getFullYear();
  const startMonth = startDate.getMonth();
  const startDay = startDate.getDate();
  
  return dateYear < startYear || 
         (dateYear === startYear && dateMonth < startMonth) || 
         (dateYear === startYear && dateMonth === startMonth && dateDay < startDay);
}

**- 逻辑 :

  • 当未选择开始时间时,不禁用任何日期
  • 当已选择开始时间时,通过分别比较年、月、日,禁用所有早于开始日期的日期
  • 关键点 :仅比较日期部分,忽略时间部分,允许选择与开始日期相同的日期**

结束小时禁用逻辑

**逻辑 :

  • 只有当开始日期和结束日期为同一天时,才禁用小时
  • 禁用所有小于开始时间小时数的小时选项
  • 不同天时,允许选择任何小时**
java 复制代码
const disabledEndHours = () => {
  if (!startForm.value.startTime || !startForm.value.endTime) return [];
  const startDate = new Date(startForm.value.startTime);
  const endDate = new Date(startForm.value.endTime);
  // 比较年月日是否相同
  if (startDate.getFullYear() !== endDate.getFullYear() ||
      startDate.getMonth() !== endDate.getMonth() ||
      startDate.getDate() !== endDate.getDate()) {
    return []; // 不同天,不禁用任何小时
  }
  const currentHour = startDate.getHours();
  return Array.from({ length: currentHour }, (_, i) => i);
}

结束分钟禁用逻辑

**逻辑 :

  • 只有当开始日期和结束日期为同一天且同一小时时,才禁用分钟
  • 禁用所有小于开始时间分钟数的分钟选项
  • 不同天或不同小时时,允许选择任何分钟**
java 复制代码
const disabledEndMinutes = () => {
  if (!startForm.value.startTime || !startForm.value.endTime) return [];
  const startDate = new Date(startForm.value.startTime);
  const endDate = new Date(startForm.value.endTime);
  // 先比较年月日
  if (startDate.getFullYear() !== endDate.getFullYear() ||
      startDate.getMonth() !== endDate.getMonth() ||
      startDate.getDate() !== endDate.getDate()) {
    return []; // 不同天,不禁用任何分钟
  }
  // 再比较小时
  if (startDate.getHours() !== endDate.getHours()) {
    return []; // 不同小时,不禁用任何分钟
  }
  const currentMinute = startDate.getMinutes();
  return Array.from({ length: currentMinute }, (_, i) => i);
}

默认时间设置

  • 逻辑 :默认将结束时间选择器的时间部分设置为23:59:59

  • 应用场景 :当未手动选择结束时间时,提供一个默认的结束时间

java 复制代码
const defaultTime = () => {
    var now = new Date(); // 获取当前日期和时间
    now.setHours(23); // 设置小时为23
    now.setMinutes(59);
    now.setSeconds(59);
    return now
}

四、核心逻辑总结

开始时间限制 :

  • 不能选择过去的日期

  • 不能选择当天当前时间之前的小时和分钟

结束时间限制 :

  • 不能选择早于开始日期的日期

  • 只有与开始日期为同一天时,才限制小时不能早于开始时间的小时

  • 只有与开始日期和小时都相同时,才限制分钟不能早于开始时间的分钟

日期比较原则 :

  • 所有日期比较都只比较年、月、日部分,忽略时间

  • 时间比较仅在日期相同的前提下进行 五、关键函数解析

函数名 参数 返回值 核心逻辑 disabledDate date boolean 禁止选择今天之前的日期 disabledEndDate date boolean 结束日期不能早于开始日期 disabledHours - number[] 禁用当前时间之前的小时 disabledEndHours - number[] 同一天时禁用开始时间之前的小时 disabledMinutes - number[] 禁用当前时间之前的分钟 disabledEndMinutes - number[] 同一天且同小时时禁用开始时间之前的分钟 defaultTime - Date 设置默认结束时间为23:59:59

相关推荐
CAD老兵1 分钟前
package.json 中 dependencies 的版本号:它真的是版本号吗?
前端·javascript
汤姆大聪明4 分钟前
Spring Cloud Gateway 服务网关
java·服务器·前端
OEC小胖胖33 分钟前
架构篇(一):告别MVC/MVP,为何“组件化”是现代前端的唯一答案?
前端·架构·mvc
alien爱吃蛋挞35 分钟前
【JavaEE】Spring Web MVC(上)
前端·spring·java-ee
拾光拾趣录1 小时前
一个 ID 溢出引发的线上资损
前端·javascript
液态不合群1 小时前
JavaScript 编年史:探索前端界巨变的幕后推手
开发语言·前端·javascript
拾光拾趣录1 小时前
一个链接,两种命运
前端
油丶酸萝卜别吃1 小时前
JS深度克隆对象(克隆时包含函数)
开发语言·javascript·ecmascript
清沫1 小时前
上下文工程(Context Engineering)
前端·claude·cursor
江城开朗的豌豆1 小时前
Element UI 避坑指南:6年老前端的血泪总结
前端·javascript·vue.js