el-date-picker 组件 监听输入的内容 并按照时间格式 格式化

这个时间选择组件在输入的时候是监听不到输入的值的,所以我们在外层再套个div,然后用获取焦点事件去操作dom

页面中

复制代码
 <div id="inParkingData">
      <el-date-picker
            v-model="indateRange"
            size="small"
            value-format="yyyy-MM-dd HH:mm:ss"
            type="datetimerange"
            range-separator="-"
            start-placeholder="开始日期"
            end-placeholder="结束日期"
            :default-time="['00:00:00', '23:59:59']"
            @focus="inParkingDataFocus('inParkingData', indateRange)"
          >
      </el-date-picker>
</div>

js文件中

复制代码
// 获取 dom 方法
export function gainFocus(e, data) {
  console.log(e, data, "==11==");
  var _self = this;
  var inDataInput = document.getElementById(e).getElementsByTagName("input")[0];
  var outDataInput = document
    .getElementById(e)
    .getElementsByTagName("input")[1];
  inDataInput.addEventListener("input", inTapEvent);
  outDataInput.addEventListener("input", outTapEvent);

  function inTapEvent() {
    console.log(inDataInput.value);
    setTimeout(() => {
      inDataInput.value = disposeData(inDataInput.value);
    }, 100);

    Vue.set(data, 0, inDataInput.value);
  }
  function outTapEvent() {
    setTimeout(() => {
      outDataInput.value = disposeData(outDataInput.value);
    }, 100);
    Vue.set(data, 1, outDataInput.value);
  }

  return data;
}

// 更改格式
function disposeData(str) {
  var value = str.split("");
  if (value.length == 4) {
    value.splice(4, 0, "-");
  }
  if (value.length == 7) {
    value.splice(7, 0, "-");
  }
  if (value.length == 10) {
    value.splice(10, 0, " ");
  }
  if (value.length == 13) {
    value.splice(13, 0, ":");
  }
  if (value.length == 16) {
    value.splice(16, 0, ":");
  }
  return value.join("");
}
相关推荐
幻云20105 分钟前
Python机器学习:筑基与实践
前端·人工智能·python
web小白成长日记7 分钟前
Vue3中如何优雅实现支持多绑定变量和修饰符的双向绑定组件?姜姜好
前端·javascript·vue.js
晴天飛 雪13 分钟前
Spring Boot 接口耗时统计
前端·windows·spring boot
0思必得021 分钟前
[Web自动化] Selenium模拟用户的常见操作
前端·python·selenium·自动化
Apifox.34 分钟前
测试用例越堆越多?用 Apifox 测试套件让自动化回归更易维护
运维·前端·后端·测试工具·单元测试·自动化·测试用例
玉梅小洋1 小时前
Chrome设置链接自动跳转新标签页而不是覆盖
前端·chrome
EndingCoder1 小时前
反射和元数据:高级装饰器用法
linux·运维·前端·ubuntu·typescript
Marshmallowc1 小时前
React性能优化:useState初始值为什么要用箭头函数?深度解析Lazy Initialization与Fiber机制
前端·react.js·性能优化·前端框架·react hooks
Coder_Boy_1 小时前
基于SpringAI的在线考试系统-试卷管理模块完整优化方案
前端·人工智能·spring boot·架构·领域驱动
摇滚侠1 小时前
Node.js 零基础教程,Node.js 和 NPM 的安装与使用
前端·npm·node.js