当前位置: 首页 > news >正文

【Element UI】表单及其验证规则详细

Form表单

    • Form表单验证
      • 1. 使用方法
      • 2. rule参数
      • 3. validator回调函数
        • 异步服务器验证

Form表单验证

Form组件提供了表单验证的功能,需要通过rules属性传入约定的验证规则,并将Form-Itemprop属性设置为需校验的字段名

1. 使用方法

结构:

<template><div><el-form :model="loginForm" status-icon :rules="loginRules" ref="loginForm" label-width="100px"class="demo-ruleForm"><el-form-item label="电话" prop="phone"><el-input v-model.number="loginForm.phone" placeholder="请输入电话" prefix-icon="el-icon-phone" /></el-form-item><el-form-item label="密码" prop="password"><el-input type="password" v-model="loginForm.password" placeholder="请输入密码" prefix-icon="el-icon-lock"show-password></el-input></el-form-item><el-form-item><el-button type="primary" @click="handleLogin">登录</el-button></el-form-item></el-form></div>
</template>

数据解释:

  1. v-model:表单数据绑定
  2. status-icon:(布尔属性)
    当设置为 true 时,表单字段在验证后会显示一个状态图标:
    ✅ 绿色对勾:表示验证通过
    ❌ 红色错误:表示验证失败
  3. :rules=“loginRules”:绑定loginRules验证规则
  4. ref:用来获取表单组件,手动触发验证
  5. label:表单名
  6. props: (表单验证)表单对象loginForm中的数据名
    如果验证失败,ElementUI 会 自动 在 <el-form-item> 下方显示错误信息(message),而 prop 就是找到数据对应规则的桥梁。
  7. prefix-icon:图标
  8. show-password:出现小眼睛可点击密码是否可见

逻辑:

export default {data() {const validatePhone = (rule, value, callback) => {if (!value) {return callback(new Error('电话不能为空'));} else {const regPhone = /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;if (!regPhone.test(value)) {callback(new Error('请输入正确的手机号'));} else {callback();}}};return {loginForm: {phone: '',password: '',},loginRules: {phone: [{ required: true, validator: validatePhone,  message: '请输入正确手机号', trigger: 'blur' }],password: [{ required: true, massage: '输入密码', trigger: 'blur' },{ min: 6, max: 20, message: '长度在6到20个字符', trigger: 'blur' }]}}},methods: {handleLogin() {this.$refs.loginForm.validate((valid) => {if (valid) {this.loading = true;alert('登陆成功!');} else {return false;}})}}
}

loginRules中每个表单项可以包含多条校验规则{},第一条若不符合则之后的校验规则则不执行
validate()方法是组件内置的,用来对表单内容进行验证

2. rule参数

参数类型说明示例
typeString字段类型邮箱验证:{ type: 'email' }
requiredBoolean是否必填{ required: true }
messageString/Function错误提示{ message: '必填项' }
triggerString/Array触发事件{ trigger: ['blur', 'change'] }
参数说明示例
pattern正则表达式验证{ pattern: /^1\d{10}$/ }
min/max数值/长度范围{ min: 6, max: 12 }
len固定长度{ len: 11 }
enum枚举值验证{ enum: ['admin', 'user'] }
whitespace禁止纯空格{ whitespace: true }
validator自定义验证函数{validator:validatePhone}

密码强度验证:{ pattern: /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}$/, message: '需包含大小写和数字' }

3. validator回调函数

validator: (rule, value, callback) => {// 验证逻辑if (/* 验证失败条件 */) {callback(new Error('错误提示信息'));} else {callback();}
}
  1. rule:Object (当前验证规则对象,包含该字段的所有验证规则信息)
  2. value:当前表单字段的值
  3. callback:验证完成后的回调函数
  • 验证成功时调用:callback();
  • 验证失败时调用:callback(new Error('错误提示信息'))
异步服务器验证
username: [{required:true,message:'请输入用户名'},{validator:(rule,value,callback)=>{checkUsernameAvaliable(value).then(available=>{if(!available){callback(new Error('用户名已存在'));}else{callback();}});},trigger:'blur'}
]

相关文章:

  • DAY 23 训练
  • Python 3.11详细安装步骤(包含安装包)Python 3.11详细图文安装教程
  • Python 基础之函数命名
  • Nginx应用场景详解与配置指南
  • 【时时三省】(C语言基础)字符数组应用举例2
  • DeepSeek-R1 Supervised finetuning and reinforcement learning (SFT + RL)
  • MATLAB安装常见问题及解决办法
  • 开源项目实战学习之YOLO11:12.4 ultralytics-models-sam-memory_attention.py源码分析
  • 强化学习中,frames(帧)和 episodes(回合)
  • 重排序模型解读 mxbai-rerank-base-v2 强大的重排序模型
  • 我司助力高校打造「智慧创新AI学习中心」
  • 互联网大厂Java求职面试:AI驱动的短视频直播平台架构设计
  • 软件设计师考试结构型设计模式考点全解析
  • 学习深度学习是否要先学习机器学习?
  • 非对称加密算法(公钥加密算法)
  • 常见位运算总结
  • 【Ubuntu】Waydroid-Linux安卓模拟器安装
  • Node.js 实战四:数据库集成最佳实践
  • TC3xx学习笔记-UCB BMHD使用详解(二)
  • [Android] 安卓彩蛋:Easter Eggs v3.4.0
  • 《歌手》回归,人均技术流,00后整顿职场
  • 高瓴、景林旗下公司美股持仓揭晓:双双增持中概股
  • 首次带人形机器人走科技节红毯,傅利叶顾捷:没太多包袱,很多事都能从零开始
  • AI含量非常高,2025上海教育博览会将于本周五开幕
  • 郑培凯:汤显祖的“至情”与罗汝芳的“赤子之心”
  • 人民日报访巴西总统卢拉:“巴中关系正处于历史最好时期”