vue 输入电话号码自动按3-4-4分割功能的实现代码


Posted in Javascript onApril 30, 2020

输入框绑定

<input class="inputBox" type="phone" 
placeholder=" 请输入手机号" 
maxlength="13" v-model="phoneNum"/>

监听事件,每次号码发生改变时触发
大体的逻辑是:先比较号码变化前后的长度,判断是输入还是删除,如果是输入的话,利用正则表达式改变号码格式。

watch: {
 phoneNum (newValue, oldValue) { // 监听电话号码
 this.phoneNum = newValue.length > oldValue.length ? newValue.replace(/\s/g, '').replace(/(\d{3})(\d{0,4})(\d{0,4})/, '$1 $2 $3') : this.phoneNum.trim()
 if (this.phoneNum.length === 13) {
 // 验证/保存的手机号码,去除空格
 this.state.checkPhoneNum = this.phoneNum.replace(/\s/g, '')
 console.log('输入的电话号码是:', this.state.checkPhoneNum)
 } 
 }
 },

效果示意

vue 输入电话号码自动按3-4-4分割功能的实现代码

附录:下面看下vue手机号按344分隔,银行卡号每4位空格分隔

实现效果:

1. 手机号输入/粘贴时,不允许输入数字外的其它字符,按344分隔,最大输入11位数字

2. 银行卡号输入/粘贴时,不允许输入数字外的其它字符,每四位用空格分隔

vue 输入电话号码自动按3-4-4分割功能的实现代码

代码:

<template>
 <div class="form">
 <p>
 手机号:
 <input v-model="mobile" type="tel" ref="mobile" maxlength="13" @keyup="inputMobile" @paste="inputMobile" />
 </p>
 <p>
 银行卡号:
 <input v-model="card" type="text" @keyup="inputCard" @paste="inputCard" />
 </p>
 </div>
</template>

js:

<script>
 export default {
 data() {
 return {
 mobile: '',
 card: ''
 }
 },
 methods: {
 inputMobile() {
 let value = this.mobile.replace(/\D/g, '').substr(0, 11) // 不允许输入非数字字符,超过11位数字截取前11位
 let len = value.length
 if (len > 3 && len < 8) {
  value = value.replace(/^(\d{3})/g, '$1 ')
 } else if (len >= 8) {
  value = value.replace(/^(\d{3})(\d{4})/g, '$1 $2 ')
 }
 this.mobile = value
 },
 inputCard() {
 this.card = this.card.replace(/\D/g, '') // 不允许输入非数字字符
 this.card = this.card.replace(/(\d{4})(?=\d)/g, '$1 ') // 4位一组,非获取匹配最后一组数字,避免删除到空格时会马上自动补齐
 }
 }
 } 
</script>

上述方案即可实现基本效果,但如果从中间开始删除或添加内容时,光标会自动跑到最后,如下:

vue 输入电话号码自动按3-4-4分割功能的实现代码

若想光标留在删除/添加内容位置,需要设置光标位置:

vue 输入电话号码自动按3-4-4分割功能的实现代码

修改js如下:

<script>
 export default {
 data () {
 return {
 mobile: '',
 card: ''
 }
 },
 methods: {
 inputMobile (e) {
 this.formatMobile(e)
 this.mobile = this.$refs.mobile.value
 },
 formatMobile (e) {
 let val = this.$refs.mobile.value // 不可直接用this.mobile,第一方便提取该方法降低代码耦合度,第二直接用this.mobile,在输入汉字时按下shift按键会导致无法再输入和删除内容
 let selStart = this.$refs.mobile.selectionStart // 选中区域左边界位置
 let mobileLen = val.length
 let value = this.getValue(e, val).substr(0, 11) // 获取输入/粘贴内容,并截取前11位
 let len = value.length
 if (len > 3 && len < 8) {
  value = value.replace(/^(\d{3})/g, '$1 ')
 } else if (len >= 8) {
  value = value.replace(/^(\d{3})(\d{4})/g, '$1 $2 ')
 }
 this.$refs.mobile.value = value
 if (selStart !== mobileLen) {
  if (selStart === 3) {
  selStart++
  }
  // 设置光标位置
  this.$refs.mobile.selectionStart = this.$refs.mobile.selectionEnd = selStart
 }
 },
 getValue(e, val) {
 let value = ''
 if (e.type === 'keyup') {
  value = val.replace(/\D/g, '')
 } else if (e.type === 'paste') {
  // window.clipboardData:IE浏览器获取剪贴板数据对象
  // event.clipboardData:Chrome, Firefox, Safari获取剪贴板数据对象
  let clipboardData = event.clipboardData || window.clipboardData;
  value = clipboardData.getData('Text'); // 获取剪贴板text格式的数据
  value = value.replace(/\D/g, '')
 }
 return value
 }
 }
 }
</script>

未实现:

不允许粘贴非数字内容到输入框还未实现,改为了提交时校验,如果有比较好的解决方案望大家提出

到此这篇关于vue 输入电话号码自动按3-4-4分割功能的实现代码的文章就介绍到这了,更多相关vue输入电话号码自动分割内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
FireFox中textNode分片的问题
Apr 10 Javascript
JS+ACTIVEX实现网页选择本地目录路径对话框
Mar 18 Javascript
node.js中的Socket.IO使用实例
Nov 04 Javascript
详解JavaScript对W3C DOM模版的支持情况
Jun 16 Javascript
JS实现Fisheye效果动感放大菜单代码
Oct 21 Javascript
javascript跨域总结之window.name实现的跨域数据传输
Nov 01 Javascript
使用JQuery实现智能表单验证功能
Mar 08 Javascript
JavaScript驾驭网页-CSS与DOM
Mar 24 Javascript
分享一个精简的vue.js 图片lazyload插件实例
Mar 13 Javascript
详解JavaScript添加给定的标签选项
Sep 17 Javascript
javascript function(函数类型)使用与注意事项小结
Jun 10 Javascript
对vuex中getters计算过滤操作详解
Nov 06 Javascript
浅谈Vue3.0新版API之composition-api入坑指南
Apr 30 #Javascript
JavaScript变量Dom对象的所有属性
Apr 30 #Javascript
vue项目中使用bpmn为节点添加颜色的方法
Apr 30 #Javascript
VSCode搭建Vue项目的方法
Apr 30 #Javascript
jQuery实现的解析本地 XML 文档操作示例
Apr 30 #jQuery
vue使用map代替Aarry数组循环遍历的方法
Apr 30 #Javascript
jQuery事件模型默认行为执行顺序及trigger()与 triggerHandler()比较实例分析
Apr 30 #jQuery
You might like
双料怀旧--SHARP GF515的维护、修理和简单调试
2021/03/02 无线电
PHP中提问频率最高的11个面试题和答案
2014/09/02 PHP
注意!PHP 7中不要做的10件事
2016/09/18 PHP
Zend Framework实现自定义过滤器的方法
2016/12/09 PHP
利用location.hash实现跨域iframe自适应
2010/05/04 Javascript
克隆javascript对象的三个方法小结
2011/01/12 Javascript
如何让div span等元素能响应键盘事件操作指南
2012/11/13 Javascript
js怎么终止程序return不行换jfslk
2013/05/30 Javascript
jquery实现鼠标拖动图片效果示例代码
2014/01/09 Javascript
javascript巧用eval函数组装表单输入项为json对象的方法
2015/11/25 Javascript
深入剖析javascript中的exec与match方法
2016/05/18 Javascript
三种带箭头提示框总结实例
2016/06/14 Javascript
功能强大的Bootstrap使用手册(一)
2016/08/02 Javascript
jQuery EasyUi 验证功能实例解析
2017/01/06 Javascript
js实现tab切换效果
2017/02/16 Javascript
js仿京东放大镜效果
2020/08/09 Javascript
[02:52]DOTA2新手基础教程 米波
2014/01/21 DOTA
[52:37]完美世界DOTA2联赛循环赛 Forest vs DM BO2第一场 10.29
2020/10/29 DOTA
浅谈Python的Django框架中的缓存控制
2015/07/24 Python
Python符号计算之实现函数极限的方法
2019/07/15 Python
Django用户认证系统 User对象解析
2019/08/02 Python
详解Python利用random生成一个列表内的随机数
2019/08/21 Python
Python连接Hadoop数据中遇到的各种坑(汇总)
2020/04/14 Python
python 爬取小说并下载的示例
2020/12/07 Python
分享一个python的aes加密代码
2020/12/22 Python
HTML5+CSS3网页加载进度条的实现,下载进度条的代码实例
2016/12/30 HTML / CSS
德国箱包网上商店:koffer24.de
2016/07/27 全球购物
苏格兰销售女装、男装和童装的连锁店:M&Co
2018/03/16 全球购物
EJB与JAVA BEAN的区别
2016/08/29 面试题
2014升学宴答谢词
2014/01/26 职场文书
集中整治工作方案
2014/05/01 职场文书
支部书记四风对照材料
2014/08/28 职场文书
校长创先争优承诺书
2014/08/30 职场文书
市场总监岗位职责
2015/02/11 职场文书
庆祝教师节主题班会
2015/08/17 职场文书
Python中生成随机数据安全性、多功能性、用途和速度方面进行比较
2022/04/14 Python