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
              }
            }
          }
        }
      }
    }
  },
相关推荐
伍哥的传说26 分钟前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
yugi98783828 分钟前
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
前端
浪裡遊40 分钟前
Sass详解:功能特性、常用方法与最佳实践
开发语言·前端·javascript·css·vue.js·rust·sass
旧曲重听11 小时前
最快实现的前端灰度方案
前端·程序人生·状态模式
默默coding的程序猿2 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
夏梦春蝉2 小时前
ES6从入门到精通:常用知识点
前端·javascript·es6
归于尽2 小时前
useEffect玩转React Hooks生命周期
前端·react.js
G等你下课2 小时前
React useEffect 详解与运用
前端·react.js
我想说一句2 小时前
当饼干遇上代码:一场HTTP与Cookie的奇幻漂流 🍪🌊
前端·javascript
funnycoffee1232 小时前
Huawei 6730 Switch software upgrade example版本升级
java·前端·华为