vue表单验证rules及validator验证器如何使用

前言

为防止用户犯错,尽可能更早地发现并纠正错误。

Element中Form (表单)组件提供了表单验证的功能,只需要通过 rules 属性传入约定的验证规则,并将 Form-Item 的 prop 属性设置为需校验的字段名即可。

注意:prop对应表单域 model 字段,使用 validate方法时,该属性是必填的。

表单验证rules

以官网给出的例子分析来看

将prop 属性设置为需校验的字段名。

vue表单验证rules及validator验证器如何使用

在data里配置要校验字段和校验规则:

required:true表示为必须输入;

message:””设置不符合校验规则时的提示信息;

trigger:””设置校验的触发方式:

‘change’:数据改变时触发;

‘blur’:失去焦点时触发;

没有进行任何输入时,不会触发change,但一定会触发blur事件。

vue表单验证rules及validator验证器如何使用

设置校验规则后,表头会出现红色*样式

vue表单验证rules及validator验证器如何使用

该示例完整代码:

<el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">  <el-form-item label="活动名称" prop="name">    <el-input v-model="ruleForm.name"></el-input>  </el-form-item>  <el-form-item label="活动区域" prop="region">    <el-select v-model="ruleForm.region" placeholder="请选择活动区域">      <el-option label="区域一" value="shanghai"></el-option>      <el-option label="区域二" value="beijing"></el-option>    </el-select>  </el-form-item>  <el-form-item label="活动时间" required>    <el-col :span="11">      <el-form-item prop="date1">        <el-date-picker type="date" placeholder="选择日期" v-model="ruleForm.date1" ></el-date-picker>      </el-form-item>    </el-col>    <el-col class="line" :span="2">-</el-col>    <el-col :span="11">      <el-form-item prop="date2">        <el-time-picker placeholder="选择时间" v-model="ruleForm.date2" ></el-time-picker>      </el-form-item>    </el-col>  </el-form-item>  <el-form-item label="即时配送" prop="delivery">    <el-switch v-model="ruleForm.delivery"></el-switch>  </el-form-item>  <el-form-item label="活动性质" prop="type">    <el-checkbox-group v-model="ruleForm.type">      <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>      <el-checkbox label="地推活动" name="type"></el-checkbox>      <el-checkbox label="线下主题活动" name="type"></el-checkbox>      <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>    </el-checkbox-group>  </el-form-item>  <el-form-item label="特殊资源" prop="resource">    <el-radio-group v-model="ruleForm.resource">      <el-radio label="线上品牌商赞助"></el-radio>      <el-radio label="线下场地免费"></el-radio>    </el-radio-group>  </el-form-item>  <el-form-item label="活动形式" prop="desc">    <el-input type="textarea" v-model="ruleForm.desc"></el-input>  </el-form-item>  <el-form-item>    <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>    <el-button @click="resetForm('ruleForm')">重置</el-button>  </el-form-item></el-form><script>  export default {    data() {      return {        ruleForm: {          name: '',          region: '',          date1: '',          date2: '',          delivery: false,          type: [],          resource: '',          desc: ''        },        rules: {          name: [            { required: true, message: '请输入活动名称', trigger: 'blur' },            { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }          ],          region: [            { required: true, message: '请选择活动区域', trigger: 'change' }          ],          date1: [            { type: 'date', required: true, message: '请选择日期', trigger: 'change' }          ],          date2: [            { type: 'date', required: true, message: '请选择时间', trigger: 'change' }          ],          type: [            { type: 'array', required: true, message: '请至少选择一个活动性质', trigger: 'change' }          ],          resource: [            { required: true, message: '请选择活动资源', trigger: 'change' }          ],          desc: [            { required: true, message: '请填写活动形式', trigger: 'blur' }          ]        }      };    },    methods: {      submitForm(formName) {        this.$refs[formName].validate((valid) => {          if (valid) {            alert('submit!');          } else {            console.log('error submit!!');            return false;          }        });      },      resetForm(formName) {        this.$refs[formName].resetFields();      }    }  }</script>

自定义校验规则

除此之外,我们还可以使用validator验证器来自定义校验规则,

举一个使用自定义验证规则来完成密码的二次验证的例子。

vue表单验证rules及validator验证器如何使用

还是和之前一样,设置prop需校验的字段名和v-model绑定值

vue表单验证rules及validator验证器如何使用

但这时,我们需要在data中自己定义校验规则,需要注意的是,设置的规则与return同级。

vue表单验证rules及validator验证器如何使用

在rules中配置要校验的字段和用到的规则

vue表单验证rules及validator验证器如何使用

完整代码如下:

<el-form :model="ruleForm" status-icon :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">  <el-form-item label="密码" prop="pass">    <el-input type="password" v-model="ruleForm.pass" autocomplete="off"></el-input>  </el-form-item>  <el-form-item label="确认密码" prop="checkPass">    <el-input type="password" v-model="ruleForm.checkPass" autocomplete="off"></el-input>  </el-form-item>  <el-form-item label="年龄" prop="age">    <el-input v-model.number="ruleForm.age"></el-input>  </el-form-item>  <el-form-item>    <el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>    <el-button @click="resetForm('ruleForm')">重置</el-button>  </el-form-item></el-form><script>  export default {    data() {      var checkAge = (rule, value, callback) => {        if (!value) {          return callback(new Error('年龄不能为空'));        }        setTimeout(() => {          if (!Number.isInteger(value)) {            callback(new Error('请输入数字值'));          } else {            if (value < 18) {              callback(new Error('必须年满18岁'));            } else {              callback();            }          }        }, 1000);      };      var validatePass = (rule, value, callback) => {        if (value === '') {          callback(new Error('请输入密码'));        } else {          if (this.ruleForm.checkPass !== '') {            this.$refs.ruleForm.validateField('checkPass');          }          callback();        }      };      var validatePass2 = (rule, value, callback) => {        if (value === '') {          callback(new Error('请再次输入密码'));        } else if (value !== this.ruleForm.pass) {          callback(new Error('两次输入密码不一致!'));        } else {          callback();        }      };      return {        ruleForm: {          pass: '',          checkPass: '',          age: ''        },        rules: {          pass: [            { validator: validatePass, trigger: 'blur' }          ],          checkPass: [            { validator: validatePass2, trigger: 'blur' }          ],          age: [            { validator: checkAge, trigger: 'blur' }          ]        }      };    },    methods: {      submitForm(formName) {        this.$refs[formName].validate((valid) => {          if (valid) {            alert('submit!');          } else {            console.log('error submit!!');            return false;          }        });      },      resetForm(formName) {        this.$refs[formName].resetFields();      }    }  }</script>

到此,关于“vue表单验证rules及validator验证器如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

文章标题:vue表单验证rules及validator验证器如何使用,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/26604

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月18日 下午10:35
下一篇 2022年9月18日 下午10:36

相关推荐

  • windows浩辰cad看图王测量尺寸不对怎么解决

    解决方法: 1、我们可以看到首次测量的距离如图所示,发现与已知尺寸不同。 2、这时候我们点击窗口最下方的对象捕捉,如图所示、 3、再点击上方测量中的“距离” 4、然后我们将鼠标移动到需要测量的点,会发现软件会自动帮你定位。 5、选取名列前茅个点后,再使用相同的方法选取第二个点。 6、选取完成后按下键…

    2022年9月21日
    79800
  • 升级服务器什么意思

    升级服务器通常意味着1、提高硬件性能、2、更新软件和操作系统、3、扩展存储容量、4、增强安全功能。提高硬件性能包括增加处理器的核心数、频率或升级到更高效的型号,以便应对增长的数据处理需求。此外,增加内存可以显著提升多任务处理和大型应用程序的运行效率。提升内存通常是应对性能瓶颈的首要解决方案,因为它直…

    2024年4月23日
    2600
  • 幽灵猎手都玩什么服务器

    摘要: 幽灵猎手玩家偏爱的服务器通常是基于几个因素选择的:1、在线人数多;2、服务器稳定性好;3、社区氛围友好;4、延迟低。尤其是在线人数多,这保证了玩家能够在任何时段找到合作伙伴,进行团队任务或是参与多人副本。服务器人口不仅反映了游戏的活跃度,也是社交互动的基础,从而影响游戏体验的整体质量。 一、…

    2024年4月25日
    800
  • torrent文件有什么作用

    torrent是BT种子文件,其本质是文本文件;torrent文件中包含Tracker信息和文件信息两部分,Tracker信息主要是BT下载中需要用到的Tracker服务器的地址和针对Tracker服务器的设置,文件信息是根据对目标文件的计算生成的,计算结果根据BitTorrent协议内的B编码规则…

    2022年9月8日
    97700
  • App崩溃的6个常见原因是什么

    人们讨厌应用程序崩溃,尤其是是程序减速或卡死几秒钟这样的现象。根据Dimensional Research的一项调查,61%的用户希望程序在4秒内启动,而49%的用户希望在2秒内响应输入。 如果应用发生崩溃,冻结或报错等现象,53%的用户会将APP卸载。 无论您的对象是消费者还是企业,崩溃问题会令他…

    2022年9月2日
    1.7K00
  • Git远程仓库配置SSH怎么实现

    1. 设置本地git账户邮箱和用户名 输入命令git config –global user.name “Git账号”以及git config –global user.email “Git邮箱”。 输入命令git config –global –list,查看配置是否正确。 2. 生成新的…

    2022年9月20日
    70100
  • vlookup函数匹配不出来的原因是什么

    vlookup函数匹配不出来的原因 一、单元格空白 1、首先任选一个单元格,输入“=E2=A9”,回车查看结果。 2、如果和图示一样,显示“FALSE”,说明原本应该一致的“E2”和“A9”并不一致。 3、接着我们在对应一列中使用“LEN”函数,可以看到数值不一样,一个3一个5。 4、这时候,我们只…

    2022年9月24日
    2.9K00
  • 数据库mdf文件能恢复吗

    数据库mdf文件可以恢复吗: 答:是可以恢复的。 方法一、 1、把mdf文件和ldf文件拷贝到数据库的默知认路径道C:Program FilesMicrosoft SQL ServerMSSQL10.MSSQLSERVERMSSQLDATA里。 2、在sqlserver里新建个查询,执行下面代码。 …

    2022年9月8日
    67500
  • 电脑驱动坏了如何修复

    电脑驱动坏了修复方法: 方法一: 1、首先右键点击此电脑,打开“管理”计算机。 2、接着我们进入左边的“设备管理器” 3、然后找到坏了的电脑驱动,右键选中它点击“卸载设备” 4、卸载完成后,再重启电脑,就会自动为你安装了。 方法二: 1、如果系统自动修复不了,那么可以使用驱动软件来修复。 2、现在几…

    2022年9月21日
    1.5K00
  • cad快速看图标注看不见怎么解决

    cad快速看图标注看不见解决方法: 1.把图纸上传到快看云盘,然后从云盘列表里打开这个图,点左侧的【同步标注】,名列前茅次使用云盘的请先登录账号、创建项目; 2.提示同步成功后,点云盘右上角的【成员】按钮,把对方的CAD快速看图账号添加为成员; 3.添加完成后,再点图纸左侧功能里的【成员协作】&#8…

    2022年9月1日
    1.2K00
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部