VUE Element-ui输入手机号加横线(三四四)或增加空格

一、问题描述:

    项目中需要用到手机号每添加后增加空格或增加横线。三四四的逻辑。那么,在vue,element-ui 组件中,如何实现呢。

二、效果图:

三、实现代码:

 <template slot="mobile">
    <el-input v-model="obj.mobile" placeholder="请输入手机号" @blur="checkRepeat" v-on:input="validateMobile"></el-input>
 </template>
 validateMobile (val) {
      if (val.length < 13) {
        if (val.length > 3 && val.length < 7) {
          val = val.replace(/\s/g, '-').replace(/[^\d]/g, '-').replace(/(\d{3})(?=\d)/g, '$1 ')
        } else if (val.length >= 7) {
          val = val.replace(/\s/g, '-').replace(/[^\d]/g, '-').replace(/(\d{4})(?=\d)/g, '$1 ')
        }
        this.$set(this.obj, 'mobile', val)
      }
 }

四、思路:

1、在组件的el-input标签中添加input事件的监听,change事件是对el-input的事件,会在blur事件后触发,所以要用input事件。

2、正则处理 val = val.replace(/\s/g, '-').replace(/[^\d]/g, '-').replace(/(\d{3})(?=\d)/g, '$1 ')

3、set方法。

 

ps: 觉得还是空格会好些,提交数据时trim下就可以,产品的逻辑是留下横线。。。。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值