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

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

用于个人记录

el-date-picker 组件 监听输入的内容 并按照时间格式 格式化_el-date-picker手动输入-CSDN博客

 <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>
// 获取 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("");
}
 
 
 
// 记得引入
inParkingDataFocus(){
    this.indateRange= gainFocus('inParkingData', indateRange)
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值