在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中的表单异步校验方法封装的更多相关文章

  1. vue中form 表单常用校验封装(async-validator)

    新建一个js校验文件validate.js export const regular = { // 验证自然数 naturalNumber: /^(([0-9]*[1-9][0-9]*)|(0+))$ ...

  2. html中form表单的使用方法和介绍

    from表单的使用方法 一.表单赏析 二.了解表单功能:用于搜集不同类型的用户输入的内容 有了表单,网页的内容可以由用户自己创建,那么对于网页来说,我们既是网页创建都者,也是网页的消费者. 三.常用的 ...

  3. .net mvc中的表单异步提交

    // // 摘要: // 将 <form> 开始标记写入响应. // // 参数: // ajaxHelper: // AJAX 帮助器. // // actionName: // 将处理 ...

  4. 纯小白入手 vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单

    vue3.0 CLI 真小白一步一步入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html 我的 github 地址 - vue3.0St ...

  5. vue中的表单

    v-model指令实现表单双向绑定数据.触发文本框的input事件.一.文本框 <div id="J_app"> <p>{{ info }}</p&g ...

  6. VUE中关于表单提交的简单实现

    main.js import Vue from "../vue.js"; import App from "./App.js"; //启动 new Vue({ ...

  7. Vue中Form表单验证无法消除验证问题

    iView的表单api给出了一个resetFields方法,用于重置整个表单输入的内容并清除验证提示. 但是有时候需要只消除部分的iview的resetFields方法源码是这样的resetField ...

  8. vue中将验证表单输入框的方法写在一个js文件中(表达式验证邮箱、身份证、号码、两次输入的密码是否一致)

    文章目录 1.实现的效果 2.编写的js文件(这里写在了api文件下) 3.在vue页面中引入(script) 4.页面代码 1.实现的效果 20220606_154646 2.编写的js文件(这里写 ...

  9. vue中提交表单后如何清空

    只需要在提交方法里写上this.form={brand_right:0}即可.

随机推荐

  1. union查询

     select id, uid, money, FROM_UNIXTIME(created) as created, type FROM  (  #type=1是  cjw_finance_bonus ...

  2. C# Designer.cs

    designer.cs 是窗体设计器生成的代码文件,作用是对窗体上的控件做初始化工作(在函数InitializeComponent()中) VS2003以前都把这部分代码放到窗体的cs文件中,由于这部 ...

  3. 第30天:DOM对象操作

    JS包括三部分:ECMAscript.DOM(文档对象).BOM(浏览器对象) 一.DOM(文档对象)DOM树节点(元素.属性.标签.标记等都是节点) 二.访问节点 documment.getElem ...

  4. Andorid API Package ---> android

    包名: android                                                        Added in API level 1  URL:http:// ...

  5. Oracle 物化视图创建以及常见问题

    create materialized view MV_XXXXrefresh fast on commitwith rowidenable query rewriteasselect * from ...

  6. 【题解】HNOI2004敲砖块

    题目传送门:洛谷1437 决定要养成随手记录做过的题目的好习惯呀- 这道题目乍看起来和数字三角形有一点像,但是仔细分析就会发现,因为选定一个数所需要的条件和另一个数所需要的条件会有重复的部分,所以状态 ...

  7. Android ListView的优化

    最近的项目中有通讯录这个模块,里面的通讯录涉及的联系人数量很大,导致在加载页面的时候有点卡,所以就必须得进行优化,优化的最终实现理论是什么?就是让ListView一次性加载的数据较少,后续根据用户操作 ...

  8. UVA.297 Quadtrees (四分树 DFS)

    UVA.297 Quadtrees (四分树 DFS) 题意分析 将一个正方形像素分成4个小的正方形,接着根据字符序列来判断是否继续分成小的正方形表示像素块.字符表示规则是: p表示这个像素块继续分解 ...

  9. bzoj1706: [Usaco2007 Nov]relays 奶牛接力跑 (Floyd+新姿势)

    题目大意:有t(t<=100)条无向边连接两点,求s到e刚好经过n(n<=10^7)条路径的最小距离. 第一反应分层图,但是一看n就懵逼了,不会写.看了题解之后才知道可以这么玩... 首先 ...

  10. [zhuan]动态链接库中的.symtab和.dynsym

    http://blog.csdn.net/beyond702/article/details/50979340 原文如下: shared library (.so) "Program Lib ...