在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. Kafka Streams演示程序

    本文从以下六个方面详细介绍Kafka Streams的演示程序: Step 1: 下载代码 Step 2: 启动kafka服务 Step 3: 准备输入topic并启动Kafka生产者 Step 4: ...

  2. server2003 必要的系统优化和安全设置

    修改远程桌面端口: Windows 2003系统中的远程终端服务是一项功能非常强大的服务,同时也成了入侵者长驻主机的通道,入侵者可以利用一些手段得到管理员账号和密码并入侵主机.下面,我们来看看如何通过 ...

  3. [HNOI2009]有趣的数列 卡特兰数

    题面:[HNOI2009]有趣的数列 题解: 观察到题目其实就是要求从长为2n的序列中选n个放在集合a,剩下的放在集合b,使得集合a和集合b中可以一一对应的使a中的元素小于b. 2种想法(实质上是一样 ...

  4. C#基础-连接Access与SQL Server

    1.连接Access数据库 string strConnection = "Provider=Microsoft.Ace.OleDb.12.0; Data Source=" + S ...

  5. POJ2406:Power Strings——题解

    http://poj.org/problem?id=2406 就是给一个串,求其循环节的个数. 稍微想一下就知道,KMP中nxt数组记录了所有可与前面匹配的位置. 那么如果我们的循环节长度为k,有n个 ...

  6. BZOJ1026:[SCOI2009]windy数——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1026 Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2 ...

  7. [bzoj] 2002 弹飞绵羊 || LCT

    原题 简单的LCT练习题. 我们发现对于一个位置x,他只能跳到位置x+k,也就是唯一的父亲去.加入我们将弹飞的绵羊定义为跳到了n+1,那么这就形成了一棵树.而因为要修改k,所以这颗树是动态连边的,那么 ...

  8. CF916E Jamie and Tree 解题报告

    CF916E Jamie and Tree 题意翻译 有一棵\(n\)个节点的有根树,标号为\(1-n\),你需要维护一下三种操作 1.给定一个点\(v\),将整颗树的根变为\(v\) 2.给定两个点 ...

  9. UVA.129 Krypton Factor (搜索+暴力)

    UVA.129 Krypton Factor (搜索+暴力) 题意分析 搜索的策略是:优先找长串,若长串不合法,则回溯,继续找到合法串,直到找到所求合法串的编号,输出即可. 注意的地方就是合法串的判断 ...

  10. bzoj2733: [HNOI2012]永无乡(splay+启发式合并/线段树合并)

    这题之前写过线段树合并,今天复习Splay的时候想起这题,打算写一次Splay+启发式合并. 好爽!!! 写了长长的代码(其实也不长),只凭着下午的一点记忆(没背板子...),调了好久好久,过了样例, ...