关于Vue开发中的一些踩坑记录(三)

本文记录了Vue开发中关于async/await在生命周期钩子内无法阻塞执行的问题,提出了利用setTimeout实现同步效果的解决方案。另外,针对带指定格式的input框,讨论了如何在Element UI的input组件上实现手机号码或银行卡号等格式的自动补充,以及处理粘贴和手动输入的不同事件。通过正则表达式和状态变量管理,确保输入格式的正确性。
摘要由CSDN通过智能技术生成

一、async&await在生命周期中的使用

如果你希望在生命周期中做到阻塞异步,ES6中虽然提供了aysnc的语法糖,但是在钩子函数中使用是无法生效的,如:

async created(){
   
	await this.getList();
}
mounted(){
   
	this.format()
}
//这里依然会是执行完mounted()中的this.format()之后才执行this.getList()

原理很简单,使用async/await的钩子内部的异步代码是无法起到阻塞钩子主线程执行的作用的,如果想达到同步执行的效果,应该使用任务队列的特性,用setTimeout()把任务排入队列里按顺序执行。

二、带指定格式的input框

有些时候,我们需要用户输入的表单信息带有固定格式,如手机号码、银行卡号,网关地址等,如下图:
在这里插入图片描述
如果你使用的是element的input组件,那么调用change事件是不太可行的,必须另外触发原生的input事件,并且要做到自动补充’-'效果,需要使用正则表达式或自己建立一个映射关系来做验证。
同时,手动输入和复制粘贴是触发不同事件的,但是vue本身组件是不支持的,需要用.native修饰符来触发@paste粘贴事件:

<el-input
     v-model="form.gw_id"
     maxlength="23"
     v-on:input="formatGw_id($event)"
     @paste.native="handlePaste($event)"
     placeholder="23-7C-06-FF-FE-2B-0C-B0"
 ></el-input>

具体如何进行自动补充和判断是粘贴文白还是input手输文本,则需要我们自己定义一个变量来监察状态,具体代码逻辑如下:

 // 判断网关id的横杠位置与字母
    judgeGw_id(param, mode) {
   
      if (mode === "-"
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值