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 分钟前
为什么今天还会有新语言?MoonBit 想解决什么问题?
前端·后端·程序员
西洼工作室3 分钟前
unipp+vue3+python h5+app极验验证码集成全流程解析
前端·uni-app·全栈·极验
ZC跨境爬虫3 分钟前
跟着 MDN 学 HTML day_15:(媒体缓冲、拖动与时间范围控制)
前端·笔记·ui·html·edge浏览器·媒体
李白的天不白19 分钟前
webpack 与 webpack-cli 版本匹配问题
前端·webpack·node.js
CDN36020 分钟前
[硬核] 你的DNS正在“裸奔”?用Python手撕DNS劫持与隧道检测逻辑
开发语言·网络·python
tool21 分钟前
Hermes Agent 从安装到生产:我的完整踩坑记录
前端
froginwe1124 分钟前
jQuery 添加元素
开发语言
zhangfeng113327 分钟前
PHP 语法检查命令 php -l “$file“ > /dev/null 2>&1;
开发语言·php
csbysj202027 分钟前
解释器模式
开发语言
kyriewen1129 分钟前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·gpt·ai·copilot