vue中的表单异步校验方法封装
在vue项目的开发中,表单的验证必不可少,在开发的过程中,用的是vue+iview的一套,我们知道iview的表单验证是基于async-validator,对于async-validator不熟悉的可以去官网看看,https://github.com/yiminghe/async-validator;
1.普通的自定义验证
<Col span="24">
<FormItem
label="确认密码"
prop="passwordrepeat"
class="login-bottom">
<Input
type="password"
v-model="formInline.passwordrepeat"
placeholder="再输一次">
</Input>
</FormItem>
</Col>
其中prop是必须的,所有的验证都是基于prop来进行的,
先在data里面定义方法validatePassCheck 如下:
const validatePassCheck = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'));
} else if (value !== this.formInline.password) {
callback(new Error('两次密码输入不一致'));
} else {
callback();
}
};
接着写验证条件,把上面的方法写到validator
ruleInline: {
passwordrepeat: [
{ validator: validatePassCheck,required: true, trigger: 'blur' },
{ type: 'string', min: 4, message: '内容太短', trigger: 'blur' }
], },
这样存在的问题就是每个都要创建这个方法,会显得很麻烦,于是我们需要封装一个通用的函数来做异步校验
/*
**异步校验表单重复的方法
**传入json的格式
json={
url:'ssss', //验证需要的url
method:'get', //默认get方法
tip:'存储名称重复' //不写默认提示
response:exist //后端get方法返回重复提示的字段,默认为exist,exist为true代表重复
}
*/
Vue.prototype.checkBackNameRepeat = (json) => {
let url = json.url;
let editName = ""
//利用闭包返回一个函数,因为在vue文件中自定义的验证必须是个函数,闭包帮我们保存一些需要的东西
return function(rule, value, callback){//这三个参数是验证函数必须传入的,可以参考以上的validatePasscheck函数
let _url = url;
_url = _url.replace("{value}", value);
/*保存后端第一次返回数据,本次数据在编辑状态下不能算重复*/
if(json.edit && !editName){
editName = value;
}
if(editName == value){
callback();
return;
}
//head方法,返回404则代表不重复,否则就是重复
if( json.method && json.method.toUpperCase() === 'HEAD' ){
axios.head( _url ).then( (e) => {
callback( new Error( json.tip?json.tip:'名称重复' ) );//callback运行带有参数代表验证不通过
},( err)=>{
callback();//callback运行无参数代表验证通过
})
//剩下就是get方法,返回指定的条件才是重复和不重复的区别
}else{
axios.get( _url ).then( (e) => {
if( e.data.response[json.response] || e.data.response.exist ){
callback( new Error( json.tip?json.tip:'名称重复' ) );
}else{
callback();
}
},( err ) => {
callback();
})
}
}
}
上面写好了通用的方法后,在需要校验的vue文件引入该方法,然后在需要验证的字段的自定义验证validator执行这个方法,写入一些配置参数,该方法执行后会返回一个带三个参数的函数就是我们之前不封装需要的写法,如下,到目前,我们的异步校验封装就算完成了
rules:{
name:[
{ required: true, message: '存储名称是必须的', trigger: 'blur' },
{ pattern:/^([a-z0-9]([a-z0-9-.]*)[a-z0-9])$|^([a-z0-9])$/, message: '只能输入小写字母、数字、点号.和横线-并且点号 . 和横线 - 不能在开头或结尾', trigger: 'blur' },
{ min:2, message:'名称太短!',trigger:'blur'},
{ max:50, message:'名称太长!',trigger:'blur'},
{ validator: this.checkBackNameRepeat({
url:"wave/v1/pvc/" + this.$store.state.token.UserNamespace + "/{value}",
method:'head',
tip:'存储名称重复',
response:'exist'
}), trigger: 'blur' }
], }
vue中的表单异步校验方法封装的更多相关文章
- vue中form 表单常用校验封装(async-validator)
新建一个js校验文件validate.js export const regular = { // 验证自然数 naturalNumber: /^(([0-9]*[1-9][0-9]*)|(0+))$ ...
- html中form表单的使用方法和介绍
from表单的使用方法 一.表单赏析 二.了解表单功能:用于搜集不同类型的用户输入的内容 有了表单,网页的内容可以由用户自己创建,那么对于网页来说,我们既是网页创建都者,也是网页的消费者. 三.常用的 ...
- .net mvc中的表单异步提交
// // 摘要: // 将 <form> 开始标记写入响应. // // 参数: // ajaxHelper: // AJAX 帮助器. // // actionName: // 将处理 ...
- 纯小白入手 vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单
vue3.0 CLI 真小白一步一步入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html 我的 github 地址 - vue3.0St ...
- vue中的表单
v-model指令实现表单双向绑定数据.触发文本框的input事件.一.文本框 <div id="J_app"> <p>{{ info }}</p&g ...
- VUE中关于表单提交的简单实现
main.js import Vue from "../vue.js"; import App from "./App.js"; //启动 new Vue({ ...
- Vue中Form表单验证无法消除验证问题
iView的表单api给出了一个resetFields方法,用于重置整个表单输入的内容并清除验证提示. 但是有时候需要只消除部分的iview的resetFields方法源码是这样的resetField ...
- vue中将验证表单输入框的方法写在一个js文件中(表达式验证邮箱、身份证、号码、两次输入的密码是否一致)
文章目录 1.实现的效果 2.编写的js文件(这里写在了api文件下) 3.在vue页面中引入(script) 4.页面代码 1.实现的效果 20220606_154646 2.编写的js文件(这里写 ...
- vue中提交表单后如何清空
只需要在提交方法里写上this.form={brand_right:0}即可.
随机推荐
- MVC学习笔记:入门
1.controller/action action直接返回字符串,适用于不需要返回大量html的业务,类似一般处理程序. 如果需要返回大量html代码,需要返回view(); View文件夹中需添加 ...
- HDU 2148 Score
http://acm.hdu.edu.cn/showproblem.php?pid=2148 Problem Description 转眼又到了一年的年末,Lele又一次迎来了期末考试.虽然说每年都要 ...
- AutoHotKey 快速入门
AutoHotKey 是一个免费的键盘宏程序,可以用于配置键盘快捷键.鼠标事件 以及摇杆事件,还可以在输入文本的时候对文本进行扩展(自动补全) 第一个脚本 新建文件test.ahk并输入以下内容: ^ ...
- Tomcat 设计模式分析
门面设计模式 门面设计模式在 Tomcat 中有多处使用,在 Request 和 Response 对象封装中.Standard Wrapper 到 ServletConfig 封装中.Applica ...
- NetScaler SNIPs Bound To An Interface Without A VLAN
NetScaler SNIPs Bound To An Interface Without A VLAN https://www.citrix.com/blogs/2014/04/09/work-yo ...
- 转:Scipy入门
Scipy入门 转:http://notes.yeshiwei.com/scipy/getting_started.html 本章节主要内容来自 Getting Started .翻译的其中一部分,并 ...
- [JSOI2009]计数问题 二维树状数组
---题面--- 题解: 二维树状数组的板子题,,,学了这么久第一次写二维树状数组,惭愧啊. 怎么写就不说了,看代码吧. 跟普通的是一样的写法 #include<bits/stdc++.h> ...
- 51NOD 1227:平均最小公倍数——题解
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1227 懒得打公式了,看这位的吧:https://blog.csdn.ne ...
- AOJ.综合训练.2016-12-8
提示:多个题目的代码采用了C ++的写法,对应编译器选择G ++,请不要直接复制代码. 下周实验考试,GOOD LUCK! 感谢汪神提供E题C语言代码 所有题目已更新为C语言写法 所有题目已更新为C语 ...
- 直通BAT面试算法精讲课 --动态规划
1.有数组penny,penny中所有的值都为正数且不重复.每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim(小于等于1000)代表要找的钱数,求换钱有多少种方法. 给定数 ...