el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式 【仅双日历 datetimerange专用】

javascript 复制代码
// 【仅双日历 datetimerange】 专用
export function handleDateTimeInput(
  e: KeyboardEvent,
  formData: Record<string, any>,
  field: string
) {
  // 1. 只允许数字 + 控制键
  const isNumber = /^[0-9]$/.test(e.key)
  const isControl = ['Backspace', 'Delete', 'ArrowLeft', 'ArrowRight', 'Tab'].includes(e.key)

  if (!isNumber && !isControl) {
    e.preventDefault()
    return
  }
  if (isControl) return

  setTimeout(() => {
    const input = e.target as HTMLInputElement
    if (!input) return

    let val = input.value.replace(/\D/g, '')
    if (val.length < 8) return

    const date = val.slice(0, 8)
    const time = val.slice(8, 14)
    const y = date.slice(0, 4)
    const m = date.slice(4, 6)
    const d = date.slice(6, 8)
    let dateStr = `${y}-${m}-${d}`

    let timeStr = ''
    if (time.length >= 1) timeStr = time.slice(0, 1)
    if (time.length >= 2) timeStr = time.slice(0, 2)
    if (time.length >= 3) timeStr = time.slice(0, 2) + ':' + time.slice(2, 3)
    if (time.length >= 4) timeStr = time.slice(0, 2) + ':' + time.slice(2, 4)
    if (time.length >= 5) timeStr = time.slice(0, 2) + ':' + time.slice(2, 4) + ':' + time.slice(4, 5)
    if (time.length >= 6) timeStr = time.slice(0, 2) + ':' + time.slice(2, 4) + ':' + time.slice(4, 6)

    let final = dateStr
    if (timeStr) final += ' ' + timeStr

    input.value = final
    input.dispatchEvent(new Event('input'))

    if (val.length === 14) {

      const formattedDate = dayjs(final).format('YYYY-MM-DD HH:mm:ss')
      const isStart = input.placeholder.includes('开始')

      if (isStart) {
        formData[field][0] = formattedDate
      } else {
        formData[field][1] = formattedDate
      }

      input.dispatchEvent(new Event('change'))
    }
  }, 0)
}

使用方法:使用@keydown来进行触发

javascript 复制代码
<el-date-picker
v-model="form.effectiveTime"
type="datetimerange"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD HH:mm:ss"
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
style="width: 360px"
@keydown="handleDateTimeInput($event, form, 'effectiveTime')"
/>
相关推荐
anOnion4 分钟前
构建无障碍组件之Slider Pattern
前端·html·交互设计
云水一下11 分钟前
JavaScript 从零基础到精通系列:前世今生与编程启蒙
前端·javascript
月亮邮递员61611 分钟前
Markdown语法总结
开发语言·前端·javascript
printfLILEI11 分钟前
php中的类与对象以及反序列化
linux·开发语言·php
曹牧12 分钟前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
代码中介商12 分钟前
深入解析STL中的stack、queue与priority_queue
开发语言·c++
彦为君17 分钟前
JavaSE-07-异常机制
java·开发语言·后端·python·spring
Kurisu57532 分钟前
雾锁王国修改器下载2026最新
前端·修改器代码
OxyTheCrack34 分钟前
【Golang】简述make与new内置函数以及两者的区别
开发语言·golang
Rain50944 分钟前
mini-cc 的 MCP 协议:给 AI 装个 USB-C 接口
c语言·开发语言·前端·人工智能·架构·node.js·ai编程