iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue表单验证rules及validator验证器如何使用
  • 909
分享到

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

2023-07-02 16:07:13 909人浏览 薄情痞子
摘要

这篇文章主要介绍“Vue表单验证rules及validator验证器如何使用”,在日常操作中,相信很多人在vue表单验证rules及validator验证器如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答

这篇文章主要介绍“Vue表单验证rules及validator验证器如何使用”,在日常操作中,相信很多人在vue表单验证rules及validator验证器如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”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验证器如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: vue表单验证rules及validator验证器如何使用

本文链接: https://www.lsjlt.com/news/343146.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c语言怎么保证除完还是小数
    在 c 语言中,整数除法只能得到整数结果,要得到小数结果,需将操作数显式转换为浮点数:将一个操作数转换为浮点数,如 float result = num1 / (float)num2;将...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾不输出空行字符
    要阻止 c 语言程序结尾输出空行字符,可以使用以下方法:将 main 函数的返回值类型改为 void;在 main 函数中显式返回 0;调用 fflush(stdout) 函数刷新标准输...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾不输出空行数据
    在 c 语言中,可通过以下方法抑制 printf() 函数在程序结束时打印末尾空行:调用 fflush() 函数刷新缓冲区,立即输出所有数据;使用 setvbuf() 函数关闭缓冲,使数...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾无空行
    在 c 中去除结尾空行的方法:使用 fflush() 刷新缓冲区。使用 setvbuf() 将缓冲模式设置为 _ionbf。使用 printf 宏,它默认禁用缓冲。 如何在 C 语言中...
    99+
    2024-05-14
    c语言
  • c语言怎么输入实数赋值
    c语言中使用scanf()函数输入实数并赋值给变量:格式:scanf("%lf", &amp;variable);%lf是格式说明符,指定输入双精度浮点数;&...
    99+
    2024-05-14
    c语言
  • c语言怎么表达负数
    c语言中,负数以减号 (-) 表示,放在数字或变量前。负数运算规则包括:绝对值取正数;加正数或负数,结果取决于绝对值大小;乘或除以正数或负数,结果由符号奇偶性决定。负数的平方始终为正数,...
    99+
    2024-05-14
    c语言
  • c语言怎么输入Jac数列
    jacobi 数列的输入和生成方法分别有:1. 直接输入法:使用 scanf() 函数逐项输入数列。2. 递归生成法:使用递归公式生成数列,需初始化数列的前两项,然后按公式生成后续项。 ...
    99+
    2024-05-14
    c语言
  • c语言怎么把数组变成字符串
    在 c 语言中,将数组转换成字符串的方法包括:使用 sprintf() 将数组格式化为字符串。使用 strcpy() 将数组复制到字符串。使用 strncpy() 将指定长度的数组复制到...
    99+
    2024-05-14
    c语言
  • c语言怎么批量注释
    批量注释 c 语言代码的方法有:使用代码编辑器:使用快捷键或菜单命令自动添加 // 注释符号。使用注释工具:如 doxygen 和 cutter,批量添加行注释、块注释和文档注释。使用脚...
    99+
    2024-05-14
    python sublime c语言
  • c语言怎么把选中的全部注释
    c语言中注释选中内容可通过以下步骤实现:选中要注释的代码。根据使用的编辑器或ide,执行注释操作,例如在visual studio中右键单击并选择“注释所选内容”。添加注释内容。保存更改...
    99+
    2024-05-14
    sublime c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作