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

表单自定义规则的校验

在 Vue 3 中使用 Element Plus 的表单组件进行自定义规则的校验非常方便。Element Plus 提供了 ElFormElFormItem 组件,它们内置了表单验证的功能。下面我将详细介绍如何使用 Element Plus 进行自定义规则的校验。

创建表单及规则

首先,你需要创建一个 ElForm 组件,并为其提供一个 model rules 对象。然后在每个 ElFormItem 中绑定 prop 属性,该属性应该对应于 model 中的字段。

示例代码

<template><el-form :model="form" :rules="rules" ref="formRef" label-width="80px"><el-form-item label="用户名" prop="username"><el-input v-model="form.username"></el-input></el-form-item><el-form-item label="密码" prop="password"><el-input v-model="form.password" type="password"></el-input></el-form-item><el-form-item><el-button type="primary" @click="submitForm">提交</el-button></el-form-item></el-form>
</template><script setup>
import { ref } from 'vue';const formRef = ref(null);
const form = ref({username: '',password: ''
});const rules = ref({username: [{ required: true, message: '请输入用户名', trigger: 'blur' },{ min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }],password: [{ required: true, message: '请输入密码', trigger: 'blur' },{ min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' },{ validator: validatePassword, trigger: 'blur' }]
});function validatePassword(rule, value, callback) {if (value === '') {callback(new Error('请输入密码'));} else {if (form.value.username === value) {callback(new Error('密码不能与用户名相同'));} else {callback();}}
}function submitForm() {formRef.value.validate((valid) => {if (valid) {alert('提交成功!');} else {console.log('验证失败');return false;}});
}
</script>

说明

  1. 定义表单模型form 是一个响应式对象,用于存储表单数据。
  2. 定义验证规则rules 对象定义了表单验证规则。
    • required: 是否必填。
    • min 和 max: 字符串长度的最小和最大值。
    • trigger: 触发验证的事件,例如 blur 表示失去焦点时触发验证,change是change:改变触发。
    • validator: 自定义验证函数。
  3. 自定义验证函数validatePassword 函数用于验证密码是否与用户名相同。
  4. 提交表单submitForm 函数调用 formRef.value.validate 方法来触发表单验证。如果所有验证都通过,则提交表单。

注意事项

  • 确保在 ElForm 上使用 ref 属性,以便可以通过引用访问表单实例。
  • 自定义验证函数的第一个参数 rule 是当前验证规则的信息,第二个参数 value 是表单字段的值,第三个参数 callback 是回调函数,用于报告验证结果。
http://www.lryc.cn/news/425776.html

相关文章:

  • JVM 有哪些垃圾回收算法(回收机制)?
  • 2024年高教社杯数学建模国赛A题思路解析+代码+论文
  • Linux中yum、vim、gcc/g++的使用
  • 基于模糊神经网络的金融序列预测算法matlab仿真
  • STM32 HAL库常用功能封装
  • golang zap日志库 打印日志时显示的源文件始终是同一个问题解决方法 zap.Option函数可选项 zap.AddCallerSkip(1) 使用示例
  • BL196MQTT远程IO模块助力智能楼宇自动化升级
  • 【面试宝典】Java面向对象面试题总结(上)
  • 如何运用独特的产业运营体系打造一流的数字媒体产业园
  • 安全基础学习-SHA-256
  • Redis中Big Key该如何解决?
  • 基于springboot的实习管理系统
  • 土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测
  • Rust 之环境搭建
  • 基于微信小程序地图实现点位标注、覆盖物、地图聊天
  • xxl-job的分片广播+单播
  • 情感分类代码
  • WPF—常用控件、属性、事件、详细介绍
  • Oracle遭遇bug导致共享内存无法分配报ORA-04031错误
  • SAP BRIM用于应收账款AR收入中台
  • LVS原理简介
  • Qt五大核心特性之元对象系统
  • 开放式耳机伤耳朵吗?开放式耳机在一定程度上保护我们的耳朵
  • JAVA打车小程序APP打车顺风车滴滴车跑腿源码微信小程序打车系统源码
  • 批量智慧:揭秘机器学习中的批量大小
  • 苹果Vision Pro生态发展:现状、挑战与未来展望
  • 湖南第一师范学院来访炼石,推动密码与数据安全合作
  • 全面解析ETL:数据仓库架构中的关键处理过程
  • keepalived的介绍与配置
  • 二叉树概念与使用