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')"
/>
相关推荐
绺年3 小时前
关于 mac 使用ssh配置
前端
LDX前端校草3 小时前
verdaccio数据迁移
前端
I疯子3 小时前
2026-04-13 打卡第 6 天
开发语言·python
断眉的派大星3 小时前
值传递和引用传递
开发语言
大邳草民3 小时前
Python 对象模型与属性访问机制
开发语言·笔记·python
炸炸鱼.3 小时前
LVS-DR 群集部署
前端·chrome·lvs
xyq20243 小时前
Swift 下标脚本
开发语言
Ava的硅谷新视界3 小时前
TypeScript 中用判别联合类型替代 instanceof 检查
前端·javascript·typescript
计算机安禾3 小时前
【数据结构与算法】第44篇:堆(Heap)的实现
c语言·开发语言·数据结构·c++·算法·排序算法·图论