vue输入框事件使用及数值校验
最近做项目,用到vue去监听输入框当中值,并且去校验值的正确性,
我们都知道 vue 当中 主要监听输入框的方法有四个:input change blur keyup.enter
他们都可以使用@+xxxx="在vue当中定义的方法",去引用实现,然后利用v-model去绑定data当中的数据,
下面我们就来介绍一下这四个方法:
一、@input(或者是v-on:input)
使用的方法:
//这个事件在用户输入时触发的 //v-model 就是你绑定的变量,输入的值会存储在这个变量当中 <input type="text" placeholder="文本框默认值" v-model="inputVal" ?v-on:input="search" value="" />
二、@change
该事件和enter事件相似,在手机上都是要经过触发虚拟键盘的搜索键才会触发事件。使用方式同input事件。
三、@keyup.enter
该事件与v-on:input事件的区别在于:input事件是实时监控的,每次输入都会调用,而@keyup.enter事件则是在pc上需要点击回车键触发,而在手机上则是需要点击输入键盘上的确定键才可触发。
四、@blur(失焦)
要满足输入框在输入完成、移到其他地方时进行验证时,需要用到该事件,用此事件进行绑定验证方法即可。
注:如果使用mintui中的mt-field标签时,对应的blur(失焦)事件要执行时,要用@blur.native.capture=""来代替@blur。
下面来简单的使用一下blur 来校验文本框当中是否输入的都是数值:
首先我们在页面当中定义一个输入框,并绑定我们在vue当中定义的方法以及变量:
? <div class="form-group"> ? ? ? ? ? ? <div class="col-sm-2 control-label">数值 //这个是最简单用来标识这个参数必填的一个标志,也就是大家经常见到的(*)--red ? ? ? ? ? ? ? ? <span style="color:red">*</span> ? ? ? ? ? ? </div> ? ? ? ? ? ? <div class="col-sm-10"> //文本框之上绑定 model和checknNum方法 ? ? ? ? ? ? ? ? <input type="text" class="form-control" v-model="test.itemValue" placeholder="数值(必填)" @blur="checkNum"/> ? ? ? ? ? ? </div> ? ? ? ? </div>
之后我们在来看一下无讹当中定义的变量以及方法:
var vm = new Vue({
?? ?el:'#rrapp',
?? ?data:{
//定义的对象
? ? ? ? test: {},
? ? ? ??? ?},
?? ?methods: {
//校验数据的方法,在这里我们不用正则表达式,使用最简单的indexOf方法
? ? ? ? checkNum:function() {
? ? ? ? ?? ?var num = vm.test.itemValue;
?? ??? ? ? ? ? ? ? ?for (var i = 1; i < num.length; i++) {
? ? ? ? ? ? ? ? if (!('0123456789'.indexOf(num.substr(i, 1)) > -1)) {
? ? ? ? ? ? ? ? ? ? alert("请输入正确的数值参数");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
?
?? ??? ?}
});
下面介绍一下indexOf这个方法:
indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。
stringObject.indexOf(searchvalue,fromindex)该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 searchvalue。 开始检索的位置在字符串的 fromindex 处或字符串的开头(没有指定 fromindex 时)。 如果找到一个 searchvalue,则返回 searchvalue 的第一次出现的位置。stringObject 中的字符位置是从 0 开始的。
提示和注释
注释:indexOf() 方法对大小写敏感!
注释:如果要检索的字符串值没有出现,则该方法返回 -1。
所以一0~9的数字去做对比,这样就能够比较出文本框输入的是不是数字了
之后就是:
必填项 后面的红色 * :<span style="color:red">*</span>这样一种写法
这就是一个最简单的vue完成数据校验的使用,以及indexOf方法的一个简单使用;
vue中常用表单校验规则整理
在 vue开发中,难免遇到各种表单校验,elementUI自带的验证往往不能满足复杂的需求。
这里整理了一些高频率用到的校验方法
1 是否合法IP地址
export function validateIP(rule, value,callback) {
? ? if(value==''||value==undefined||value==null){
? ? ? callback();
? ? }else {
? ? ? const reg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
? ? ? if ((!reg.test(value)) && value != '') {
? ? ? ? callback(new Error('请输入正确的IP地址'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
}
2 是否手机号码
?export function validatePhone(rule, value,callback) {
? ? const reg =/^[1][3-9][0-9]{9}$/;
? ? if(value==''||value==undefined||value==null){
? ? ? callback();
? ? }else {
? ? ? if ((!reg.test(value)) && value != '') {
? ? ? ? callback(new Error('请输入正确的电话号码'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
?}
3 是否身份证号码
? export function validateIdNo(rule, value,callback) {
? ? var format = /^(([1][1-5])|([2][1-3])|([3][1-7])|([4][1-6])|([5][0-4])|([6][1-5])|([7][1])|([8][1-2]))\d{4}(([1][9]\d{2})|([2]\d{3}))(([0][1-9])|([1][0-2]))(([0][1-9])|([1-2][0-9])|([3][0-1]))\d{3}[0-9xX]$/;
? ? //号码规则校验
? ? if (!format.test(value)) {
? ? ? ? callback(new Error('请输入正确身份证号'));
? ? }
? ? //区位码校验
? ? //出生年月日校验 ?前正则限制起始年份为1900;
? ? var year = value.substr(6, 4),//身份证年
? ? ? ? month = value.substr(10, 2),//身份证月
? ? ? ? date = value.substr(12, 2),//身份证日
? ? ? ? time = Date.parse(month + '-' + date + '-' + year),//身份证日期时间戳date
? ? ? ? now_time = Date.parse(new Date()),//当前时间戳
? ? ? ? dates = (new Date(year, month, 0)).getDate();//身份证当月天数
? ? if (time > now_time || date > dates) {
? ? ? ? callback(new Error('请输入正确身份证号'));
? ? }
? ? //校验码判断
? ? var c = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); ?//系数
? ? var b = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); //校验码对照表
? ? var id_array = value.split("");
? ? var sum = 0;
? ? for (var k = 0; k < 17; k++) {
? ? ? ? sum += parseInt(id_array[k]) * parseInt(c[k]);
? ? }
? ? if (id_array[17].toUpperCase() != b[sum % 11].toUpperCase()) {
? ? ? ? callback(new Error('请输入正确身份证号'));
? ? }
? ? callback();
?}
4 是否邮箱
?export function validateEMail(rule, value,callback) {
? ? const reg =/^([a-zA-Z0-9]+[-_\.]?)+@[a-zA-Z0-9]+\.[a-z]+$/;
? ? if(value==''||value==undefined||value==null){
? ? ? callback();
? ? }else{
? ? ? if (!reg.test(value)){
? ? ? ? callback(new Error('请输入正确的邮箱'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
?}
5 合法url
?export function validateURL(url) {
? ? const urlregex = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(\/($|[a-zA-Z0-9.,?'\\+&%$#=~_-]+))*$/;
? ? return urlregex.test(url);
?}
6 验证是否包含英文数字以及下划线
?export function isPassword(rule, value, callback) {
? ? const reg =/^[_a-zA-Z0-9]+$/;
? ? if(value==''||value==undefined||value==null){
? ? ? callback();
? ? } else {
? ? ? if (!reg.test(value)){
? ? ? ? callback(new Error('仅由英文字母,数字以及下划线组成'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
?}
7 检验数值的范围
export function checkMax10000(rule, value, callback) {
? ? if (value == '' || value == undefined || value == null) {
? ? ? callback();
? ? } else if (!Number(value)) {
? ? ? callback(new Error('请输入[1,10000]之间的数字'));
? ? } else if (value < 1 || value > 10000) {
? ? ? callback(new Error('请输入[1,10000]之间的数字'));
? ? } else {
? ? ? callback();
? ? }
}
8 验证数字输入框最大数值
export function checkMaxVal(rule, value,callback) {
? if (value < 0 || value > 最大值) {
? ? callback(new Error('请输入[0,最大值]之间的数字'));
? } else {
? ? callback();
? }
}
9 验证是否正整数
export function isInteger(rule, value, callback) {
? ?if (!value) {
? ? ?return callback(new Error('输入不可以为空'));
? ?}
? ?setTimeout(() => {
? ? ?if (!Number(value)) {
? ? ? ?callback(new Error('请输入正整数'));
? ? ?} else {
? ? ? ?const re = /^[0-9]*[1-9][0-9]*$/;
? ? ? ?const rsCheck = re.test(value);
? ? ? ?if (!rsCheck) {
? ? ? ? ?callback(new Error('请输入正整数'));
? ? ? ?} else {
? ? ? ? ?callback();
? ? ? ?}
? ? ?}
? ?}, 0);
}
10 验证是否是[0-1]的小数
export function isDecimal(rule, value, callback) {
? if (!value) {
? ? return callback(new Error('输入不可以为空'));
? }
? setTimeout(() => {
? ? if (!Number(value)) {
? ? ? callback(new Error('请输入[0,1]之间的数字'));
? ? } else {
? ? ? if (value < 0 || value > 1) {
? ? ? ? callback(new Error('请输入[0,1]之间的数字'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
? }, 100);
}
11 验证端口是否在[0,65535]之间
export function isPort(rule, value, callback) {
? if (!value) {
? ? return callback(new Error('输入不可以为空'));
? }
? setTimeout(() => {
? ? if (value == '' || typeof(value) == undefined) {
? ? ? callback(new Error('请输入端口值'));
? ? } else {
? ? ? const re = /^([0-9]|[1-9]\d|[1-9]\d{2}|[1-9]\d{3}|[1-5]\d{4}|6[0-4]\d{3}|65[0-4]\d{2}|655[0-2]\d|6553[0-5])$/;
? ? ? const rsCheck = re.test(value);
? ? ? if (!rsCheck) {
? ? ? ? callback(new Error('请输入在[0-65535]之间的端口值'));
? ? ? } else {
? ? ? ? callback();
? ? ? }
? ? }
? }, 100);
}
12 验证小写字母
export function validateLowerCase(val) {
? ?const reg = /^[a-z]+$/;
? ?return reg.test(val);
}
13 验证大写字母
export function validateUpperCase(val) {
? ??? ?const reg = /^[A-Z]+$/;
??? ?return reg.test(val);
}
14 验证是否两位小数
export function validateValidity (rule, value, callback){
?? ? if (!/(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/.test(value)) {
?? ? ?? ?callback(new Error('最多两位小数!!!'));
?? ? } else {
?? ? ?? ?callback();
?? ? }
}
15 中文校验
?export function validateContacts(rule, value, callback){
? ? if (!value) {
? ? ? return callback(new Error('请输入中文'))
? ? }
? ? if (!/^[\u0391-\uFFE5A-Za-z]+$/.test(value)) {
? ? ? callback(new Error('不可输入特殊字符'))
? ? } else {
? ? ? callback()
? ? }
?}
16 纯数字校验
export function validateNumber(rule, value, callback){
? ? let numberReg = /^\d+$|^\d+[.]?\d+$/
? ? if (value !== '') {
? ? ? if (!numberReg.test(value)) {
? ? ? ? callback(new Error('请输入数字'))
? ? ? } else {
? ? ? ? callback()
? ? ? }
? ? } else {
? ? ? callback(new Error('请输入值'))
? ? }
}
17 最多一位小数校验
export function onePoint(rule, value, callback){
? ? if (!/^[0-9]+([.]{1}[0-9]{1})?$/.test(value)) {
? ? ? callback(new Error('最多一位小数!!!'));
? ? } else {
? ? ? callback();
? ? }
}
18 账号校验
export function validateCode(rule, value, callback){
? ? if (!value) {
? ? ? return callback(new Error('请输入账号'))
? ? }
? ? if (!/^(?![0-9]*$)(?![a-zA-Z]*$)[a-zA-Z0-9]{6,20}$/.test(value)) {
? ? ? callback(new Error('账号必须为6-20位字母和数字组合'))
? ? } else {
? ? ? callback()
? ? }
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
查看更多关于vue中输入框事件的使用及数值校验方式的详细内容...