vue自定义指令elementui日期组件手动输入

html

bash 复制代码
 <el-form-item label="开始时间" prop="beginTime">
            <!-- :picker-options="pickerOptions" -->
            <el-date-picker
              v-model="formData.beginTime"
              v-elDateFormat
              editable
              value-format="yyyyMMdd"
              type="date"
              placeholder="请选择日期"
              clearable
              style="width: 180px"
            />
</el-form-item>

scipt

bash 复制代码
  // 自定义指令
  directives: {
    elDateFormat: {
      inserted: function(el, binding, vnode) {
        const { value: _obj } = binding
        const { context: that, data } = vnode
        const { expression: key } = data.model
        if (that && that._isVue) {
          const $this = el.children[0]
          $this.onchange = function() {
            let value = $this.value // 中文日期
            console.log(value)
            if (value.match(/\d{1,}/g) && value.length == 8) {
              value = value.replace(/^(\d{4})\D*(\d{1,2})\D*(\d{1,2})\D*/, '$1-$2-$3') // 格式化输入格式
              const time = value && value.constructor == String ? new Date(value) : value // 转换时间格式
              let keys = key.split('.') // 自定义赋值
              if (_obj) {
                const { keys: keyList } = _obj
                keys = keyList
              }
              if (keys && keys.length >= 2) {
                const [key1, key2, key3, key4] = keys
                if (key4) {
                  that[key1][key2][key3][key4] = time
                } else if (key3) {
                  that[key1][key2][key3] = time
                } else {
                  that[key1][key2] = time
                }
              } else {
                that[key] = time
              }
            }
          }
        }
      }
    }
  },
相关推荐
jingqingdai3几秒前
别用正则格式化 HTML!我用 DOM 遍历实现零风险本地格式化,老项目重构效率直接拉满
前端·重构·html
木斯佳3 分钟前
前端八股文面经大全:腾讯前端实习二、三OC面(2026-04-27)·面经深度解析
前端·状态模式
Python私教16 分钟前
如意Agent日志系统重构:从 print() 大海捞针到结构化可观测性栈
java·前端·重构
We་ct35 分钟前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划
Chengbei1144 分钟前
轻量化 Web 安全日志分析神器 星川智盾日志威胁检测、地理溯源、MITRE ATT&CK 映射,支持 Windows/macOS/Linux
前端·人工智能·安全·web安全·macos·系统安全·安全架构
风流 少年1 小时前
Python Web框架:FastAPI
前端·python·fastapi
GISer_Jing1 小时前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程
IT_陈寒1 小时前
React的useEffect把我坑惨了,这些闭包陷阱真要命
前端·人工智能·后端
前端之虎陈随易1 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·typescript·npm·node.js