vue的正则
import Vue from 'vue' export default () => { // 带小数点的数字 Vue.directive('number', { inserted: function(el) { const input = el.getElementsByTagName('input')[0] // 键盘按键被松开时,清除数据 input.onkeyup = function(e) { var val = input.value if (!val) { return } val = val.replace(/[^\d\.]/g, '') // 除了第一个点 . 外,其他直接替换掉 var index = val.indexOf('.') if (index !== -1) { var d = val.substring(0, index) var n = (val.substring(index + 1)).replace(/\./g, '') val = d + '.' + n } if (input.value !== val) { input.value = val } } // 失去焦点时清理数据 input.onblur = function(e) { var val = input.value if (!val) { return } val = val.replace(/[^\d\.]/g, '') // 除了第一个点 . 外,其他直接替换掉 var index = val.indexOf('.') if (index !== -1) { var d = val.substring(0, index) var n = (val.substring(index + 1)).replace(/\./g, '') val = d + '.' + n } if (input.value !== val) { input.value = val } } } }) // 英文或者数字 Vue.directive('word', { inserted: function(el) { const input = el.getElementsByTagName('input')[0] // 键盘按键被松开时,清除数据 input.onkeyup = function(e) { var _value = input.value if (_value == null) { return } var _result = _value.replace(/\W/g, '').replace('_', '') if (_value !== _result) { input.value = _result } } // 失去焦点时清理数据 input.onblur = function(e) { var _value = input.value if (_value == null) { return } var _result = _value.replace(/\W/g, '').replace('_', '') if (_value !== _result) { input.value = _result } } } }) // 0~9数字 Vue.directive('digits', { inserted: function(el) { const input = el.getElementsByTagName('input')[0] if(input){ // 键盘按键被松开时,清除数据 input.onkeyup = function(e) { var _value = input.value if (_value == null || _value == 0 || _value == '') { input.value = '' return } var _result = _value.replace(/\D/g, '').replace('_', '') if (_value !== _result) { input.value = _result } } // 失去焦点时清理数据 input.onblur = function(e) { var _value = input.value if (_value == null || _value == 0 || _value == '') { input.value = '' return } var _result = _value.replace(/\D/g, '').replace('_', '') if (_value !== _result) { input.value = _result } } } } }) // 只能输入数字 Vue.directive('inputNum', function(el, binding){ el = el || window.event var input = el.getElementsByTagName('input')[0] if(input){ input.onkeyup = function() { var val = input.value var modifiersObj = binding.modifiers if(modifiersObj.chart){ input.value = val.replace(/[^0-9a-zA-Z]/g, '') // 调用input事件使vue v-model绑定更新,下面相同 input.dispatchEvent(new Event("input")) return } input.value = val.replace(/[^0-9]/g, '') } } }) // 1~9数字 位置码的验证 Vue.directive('validPosCode', { inserted: function(el) { el = el || window.event var input = el.getElementsByTagName('input')[0] if(input){ input.onkeyup = function() { var val = input.value input.value = val.replace(/[^0-9]/g, '') } } } }) // 电梯注册码的指令 0-32位字符,中文算一个字符 Vue.directive('inputRegist',function(el){ el = el || window.event var input = el.getElementsByTagName('input')[0] if(input){ input.onkeyup = function() { var val = input.value var regx = /^[\u4e00-\u9fa50-9a-zA-Z]{0,32}$/; // 调用input事件使vue v-model绑定更新,下面相同 if(regx.test(val)){ }else { input.value = val.replace(/[^\u4e00-\u9fa50-9a-zA-z]/g, '') input.value = input.value.substring(0, 32) } input.dispatchEvent(new Event("input")) } } }) // 禁止输入特殊字符 正常情况下 中文,数字,英文,- _ , * , . Vue.directive('normalWords', { inserted: function(el) { const input = el.getElementsByTagName('input')[0] // 键盘按键被松开时,清除数据 input.onkeyup = function(e) { var _value = input.value if (_value == null) { return } var _result = _value.replace(/[^\a-\z\A-\Z0-9\\_\-\*\#\.\,\,\u4E00-\u9FA5\ ]/g, '') if (_value !== _result) { input.value = _result } } // 失去焦点时清理数据 input.onblur = function(e) { var _value = input.value if (_value == null) { return } var _result = _value.replace(/[^\a-\z\A-\Z0-9\\_\-\*\#\.\,\,\u4E00-\u9FA5\ ]/g, '') if (_value !== _result) { input.value = _result } } } }) // 正常单位的限制 禁止输入特殊字符 正常情况下可中文,数字,英文,- _ , * , . () () // 输入的中文括号切换成英文括号 Vue.directive('normalUnint',function(el){ el = el || window.event var input = el.getElementsByTagName('input')[0] if(input){ input.onkeyup = function() { var val = input.value var reg = /\uff08/g var reg2 = /\uff09/g var regx = /[^\a-\z\A-\Z0-9\\_\-\*\#\.\,\,\(\)\(\)\u4E00-\u9FA5\ ]/g; input.value = val.replace(regx, '').replace(reg, "(").replace(reg2, ")") input.value = input.value.substring(0, 32) input.dispatchEvent(new Event("input")) } } }) }
本文来自博客园,作者:cmwang2017,转载请注明原文链接:https://www.cnblogs.com/bm20131123/p/15219274.html