vue3 element plus 表单验证 数组嵌套对象格式验证 动态验证等

基本结构

在这里插入图片描述
model 表单数据对象
rules 验证对象
prop model 的键名

<template><el-form ref="ruleFormRef" :model="ruleForm" :rules="rules"><el-form-item label="手机号" prop="mobile"><el-input v-model="ruleForm.mobile" /></el-form-item><el-form-item label="密码" prop="pass"><el-input v-model="ruleForm.pass" type="password" /></el-form-item><el-form-item><el-button type="primary" @click="submitForm(ruleFormRef)">提交</el-button></el-form-item></el-form>
</template><script lang="ts" setup>
import { reactive, ref } from "vue";
import type { FormInstance, FormRules } from "element-plus";const phoneRegular = /^1[23456789]\d{9}$/;const ruleFormRef = ref<FormInstance>();
const ruleForm = reactive({mobile: "",pass: "",
});function customMobile(_: any, value: any, callback: any) {if (phoneRegular.test(value)) callback();else callback(new Error("请输入正确的手机号"));
}
const rules = reactive<FormRules<typeof ruleForm>>({mobile: [{ required: true, message: "请输入手机号", trigger: ["blur", "change"] },// 正则{ pattern: phoneRegular, message: "请输入正确的手机号", trigger: ["blur", "change"] },// 自定义验证{ validator: customMobile, trigger: ["blur", "change"] },],pass: [{ required: true, message: "请输入密码", trigger: ["blur", "change"] }],
});const submitForm = (formEl: FormInstance | undefined) => {if (!formEl) return;formEl.validate((valid) => {if (valid) {console.log("submit!");} else {console.log("error submit!");return false;}});
};
</script>

正则验证

const phoneRegular = /^1[23456789]\d{9}$/;const rules = reactive<FormRules<typeof ruleForm>>({mobile: [// 正则{ pattern: phoneRegular, message: "请输入正确的手机号", trigger: ["blur", "change"] },]
});

自定义函数验证

const phoneRegular = /^1[23456789]\d{9}$/;
function customMobile(_: any, value: any, callback: any) {if (phoneRegular.test(value)) callback();else callback(new Error("请输入正确的手机号"));
}
const rules = reactive<FormRules<typeof ruleForm>>({mobile: [// 自定义验证{ validator: customMobile, trigger: ["blur", "change"] },]
});

数据结构嵌套对象验证写法

在这里插入图片描述

<template><el-form ref="ruleFormRef" :model="ruleForm" :rules="rules"><el-form-item label="手机号" prop="mobile"><el-input v-model="ruleForm.mobile" /></el-form-item><el-form-item label="密码" prop="user.pass"><el-input v-model="ruleForm.user.pass" type="password" /></el-form-item><el-form-item><el-button type="primary" @click="submitForm(ruleFormRef)">提交</el-button></el-form-item></el-form>
</template><script lang="ts" setup>
const ruleForm = reactive({mobile: "",user: {pass: "",},
});const rules = reactive<FormRules<typeof ruleForm>>({mobile: [{ required: true, message: "请输入手机号", trigger: ["blur", "change"] }],"user.pass": [{ required: true, message: "请输入密码", trigger: ["blur", "change"] }],
});
</script>

数据结构为数组验证写法

<template><el-form ref="ruleFormRef" :model="ruleForm" :rules="rules"><el-form-item label="图片" prop="images"><div>请选择图片</div></el-form-item><el-form-item><el-button type="primary" @click="submitForm(ruleFormRef)">提交</el-button><el-button type="primary" @click="ruleForm.images.push('http:')">追加 images {{ ruleForm.images }}</el-button></el-form-item></el-form>
</template><script lang="ts" setup>
import { reactive, ref } from "vue";
import type { FormInstance, FormRules } from "element-plus";interface RuleForm {images: string[];
}
const ruleFormRef = ref<FormInstance>();
const ruleForm: RuleForm = reactive({images: [],
});const rules = reactive<FormRules<typeof ruleForm>>({images: [{ required: true, message: "请上传图片", trigger: ["blur", "change"] },// 定义类型必填 array ,数组 length 必须为 2{ type: "array", len: 2, message: "请上传两张图片", trigger: ["blur", "change"] },// 验证数组范围 2-4{ type: "array", min: 2, max: 4, message: "请上传2-4张图片", trigger: ["blur", "change"] },],
});const submitForm = (formEl: FormInstance | undefined) => {if (!formEl) return;formEl.validate((valid) => {if (valid) {console.log("submit!");} else {console.log("error submit!");return false;}});
};
</script>

validateField 验证具体的某个某些字段

import type { FormInstance } from 'element-plus';
const ruleFormRef = ref<FormInstance>();
const ruleForm = reactive({mobile: "",pass: "",
});ruleFormRef?.value?.validateField(['mobile'], flag => {// flag true 全部验证通过, false 验证不通过
})// 验证多个写法
ruleFormRef?.value?.validateField(['mobile','pass'], flag => {})

动态切换是否需要添加验证规则

动态修改 rules,而不是修改 prop
在这里插入图片描述

<template><el-form ref="ruleFormRef" :model="ruleForm"><el-form-item label="手机号" prop="mobile" :rules="flag ? rules['mobile'] : ruleEmpty"><el-input v-model="ruleForm.mobile" /></el-form-item><el-form-item label="密码" prop="pass" :rules="flag ? rules['pass'] : ruleEmpty"><el-input v-model="ruleForm.pass" type="password" /></el-form-item><el-form-item><el-button type="primary" @click="submitForm(ruleFormRef)">提交</el-button><el-button type="primary" @click="flag = !flag">切换 flag {{ flag }}</el-button></el-form-item></el-form>
</template><script lang="ts" setup>
import { reactive, ref } from "vue";
import type { FormInstance, FormRules } from "element-plus";const ruleFormRef = ref<FormInstance>();
const ruleForm = reactive({mobile: "",pass: "",
});const flag = ref(true);
const ruleEmpty = { required: false };
const rules = reactive<FormRules<typeof ruleForm>>({mobile: [{ required: true, message: "请输入手机号", trigger: ["blur", "change"] }],pass: [{ required: true, message: "请输入密码", trigger: ["blur", "change"] }],
});const submitForm = (formEl: FormInstance | undefined) => {if (!formEl) return;formEl.validate((valid) => {if (valid) {console.log("submit!");} else {console.log("error submit!");return false;}});
};
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/179590.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

鸿蒙原生应用/元服务开发-AGC分发如何生成密钥和和证书请求文件

HarmonyOS通过数字证书&#xff08;.cer文件&#xff09;和Profile文件&#xff08;.p7b文件&#xff09;等签名信息来保证应用的完整性&#xff0c;应用如需上架到华为应用市场必须通过签名校验。因此&#xff0c;开发者需要使用发布证书和Profile文件对应用进行签名后才能发布…

互联网程序设计HTML+CSS+JS

一、HTML基础 HTML超文本标记语言。 超文本&#xff1a;链接&#xff1b; 标记&#xff1a;标签&#xff0c;带尖括号的文本。 1、标签结构 标签要成对出现&#xff0c;中间包裹内容&#xff1b; <>里面放英文字母&#xff08;标签名&#xff09;&#xff1b; 结束…

在centos7上源码安装nginx

1. 安装必要的编译工具和依赖项 在编译Nginx之前&#xff0c;你需要安装一些编译工具和依赖项。可以通过以下命令安装&#xff1a; yum install gcc-c pcre-devel zlib-devel make 2. 下载Nginx源代码 从Nginx官网下载最新的源代码。你可以使用wget命令来下载&#xff1a; …

vue项目中实现doc/excel/pdf/图片等文件的预览

vue项目中实现doc/excel/pdf/图片等文件的预览 word预览 1. 使用vue-office-docx&#xff08;只支持docx文件预览&#xff0c;不支持doc文件&#xff09; 支持文档网络地址&#xff08;https://***.docx&#xff09;。 文件上传时预览&#xff0c;此时可以获取文件的ArrayBuf…

Python压缩、解压文件

#!/usr/bin/python3 # -*- coding:utf-8 -*- """ author: JHC file: util_compress.py time: 2023/5/28 14:58 desc: rarfile 使用需要安装 rarfile 和 unrar 并且将 unrar.exe 复制到venv/Scrpits目录下 """ import os import gzip from zipfil…

<Linux>(极简关键、省时省力)《Linux操作系统原理分析之Linux 进程管理 7》(11)

《Linux操作系统原理分析之Linux 进程管理 7》&#xff08;11&#xff09; 4 Linux 进程管理4.7 IPC 信号量机制4.7.1 信号量与信号量集合1.信号量2.信号量集合3.信号量集合的集中 4.7.2 信号量集合的创建和检索4.7.3 信号量 PV 操作4.7.4 信号量操作等待队列1.信号量操作等待队…

整数反转 Golang leecode_7

拿到手第一反应还是暴力&#xff0c;直接从低位到高位把数一个个取出来&#xff0c;然后乘以每一位的权重&#xff0c;构成一个新的反转后的整数 res 返回&#xff0c;代码如下 package mainimport ("fmt""math" )func reverse(x int) int {if x > -10…

Java 基础学习(三)循环流程控制与数组

1 循环流程控制 1.1 循环流程控制概述 1.1.1 什么是循环流程控制 当一个业务过程需要多次重复执行一个程序单元时&#xff0c;可以使用循环流程控制实现。 Java中包含3种循环结构&#xff1a; 1.2 for循环 1.2.1 for循环基础语法 for循环是最常用的循环流程控制&#xff…

redis运维(二十二)redis 的扩展应用 lua(四)

一 最佳实践 ① 铺垫 最佳实践&#xff1a;1、把redis操作所需的key通过KEYS进行参数传递2、其它的lua脚本所需的参数通过ARGV进行传递. redis lua脚本原理 Redis Lua脚本的执行原理 ② 删除指定的脚本缓存 ③ redis集群模式下使用lua脚本注意事项 1、常见报错现象 C…

SpringBoot 项目中获取 Request 的四种方法

SpringBoot 项目中获取 Request 的四种方法 方法1、Controller中加参数来获取request 注意&#xff1a;只能在Controller中加入request参数。 一般&#xff0c;我们在Controller中加参数获取HttpServletRequest&#xff0c;如下所示&#xff1a; RestController RequestMap…

『 Linux 』进程优先级

文章目录 什么是优先级Linux下的进程优先级PRI与NI使用top查看进程以及对进程的优先级的修改 进程优先级的其他概念竞争性与独立性并发与并行 什么是优先级 优先级,顾名思义,即在同一环境下不同单位对同一个资源的享有顺序; 一般优先级高的单位将优先占有该资源; 在进程当中进…

Python中如何用栈实现队列

目录 一、引言 二、使用两个栈实现队列 三、性能分析 四、应用场景 五、代码示例 六、优缺点总结 一、引言 队列&#xff08;Queue&#xff09;和栈&#xff08;Stack&#xff09;是计算机科学中常用的数据结构。队列是一种特殊的线性表&#xff0c;只允许在表的前端进行…

Leetcode 380. O(1) 时间插入、删除和获取随机元素

文章目录 题目代码&#xff08;11.28 首刷看解析&#xff09; 题目 Leetcode 380. O(1) 时间插入、删除和获取随机元素 代码&#xff08;11.28 首刷看解析&#xff09; 1.length:表示的是数组的长度 数组 2.length():表示的是字符串的长度 字符串 3.size():表示的是集合中有多…

万宾科技可燃气体监测仪科技作用全览

燃气管网在运行过程中经常会遇到燃气管道泄漏的问题&#xff0c;燃气泄漏甚至会引起爆炸&#xff0c;从而威胁人民的生命和财产安全&#xff0c;因此对燃气管网进行定期巡检是十分必要的工作。但是传统的人工巡检已不能满足城市的需要&#xff0c;除了选择增加巡检人员之外&…

#Js篇:前端的设计模式有哪些

常见的前端设计模式 单例模式 保证一个类仅有一个实例&#xff0c;并提供一个访问他的全局访问点&#xff1b;vuex常用于管理全局状态、配置信息等。 工厂模式 一个用于创建对象的接口&#xff0c;让子类决定实例化哪个类&#xff1b; 创建复杂对象或对象的组合。 策略模…

Web UI自动化测试框架

WebUI automation testing framework based on Selenium and unittest. 基于 selenium 和 unittest 的 Web UI自动化测试框架。 特点 提供更加简单API编写自动化测试。提供脚手架&#xff0c;快速生成自动化测试项目。自动生成HTML测试报告生成。自带断言方法&#xff0c;断言…

笔记:Pika Labs 3D 动画生成工具

Pika Labs 一款3D 动画生成工具 本文地址&#xff1a;https://blog.csdn.net/qq_28550263/article/details/134657306 目 录 1. 简介2. 准备2.1 安装 discord2.2 加入 Discord 频道 3. Pika 使用指南2.1 快速开始2.2 从图像到视频2.3 Pika Bot按钮2.4 提示&#xff08;Prompt&a…

Spark Streaming的基本数据流

先来介绍一下按照动静对数据的区分 静态数据 ​ 静态数据&#xff08;Static Data&#xff09;指的是在一段时间内不会或很少发生变化的数据。这种类型的数据通常是固定的&#xff0c;并且不会随着时间的推移而更新或仅偶尔更新。静态数据的典型例子包括配置文件、参考表、历…

面试题:说一下MyBatis动态代理原理?

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.MyBatis简介2.使用步骤2.1、引入依赖2.2、配置文件2.3、接口定义2.4、加载执行 3.原理解析 1.MyBatis简介 MyBatis是一个ORM工具&#xff0c;封装了JDBC的操作&a…

Redis 主从架构,Redis 分区,Redis哈希槽的概念,为什么要做Redis分区

文章目录 Redis 主从架构redis replication 的核心机制redis 主从复制的核心原理过程原理Redis集群的主从复制模型是怎样的&#xff1f;生产环境中的 redis 是怎么部署的&#xff1f;机器是什么配置&#xff1f;你往内存里写的是什么数据&#xff1f;说说Redis哈希槽的概念&…