vue ant form validate如何对数组下的表单校验

news2024/9/30 4:36:48

问题

使用Ant Design Vue校验表单时,通过validateFields,但是如何一个数组内部的校验呢?

效果图:

在这里插入图片描述

实现方式:

通过 v-for 循环渲染:name="[]"实现,我们直接看代码。

<template>
  <a-form
    ref="formRef"
    :model="formState"
    :label-col="{ style: { 'width': '150px' } }"
    :wrapper-col="{ style: { 'max-width': '350px' } }"
  >
    <!-- 其他表单项 -->
	<a-form-item>
	    <template #label>
	      path
	      <a-tooltip title="提示:。。。" >
	        <question-circle-outlined />
	      </a-tooltip>
	    </template>
	    <a-form-item
	      v-for="(item, index) in formState.path"
	      :key="index"
	      label="" // 不展示 label 标签的文本
	      :name="['path', index, 'value']"  // 通过 :name="[]" 将数组中各个数据参数,绑定到 form 表单校验中
	      :colon="index === 0 ? true : false" // 是否显示 label 后面的冒号
	      :rules="[{ required: true, trigger: 'blur', min:1, max:150, message: '请输入path'}]"
	      style="width: 500px;"
	    > 
	      <a-space>
	        <a-input 
	          style="width: 350px;" 
	          v-model:value="item.value" 
	          placeholder="请输入请求路径,可添加多个" 
	         />
	        <PlusCircleOutlined
	          v-if="formState.path.length === index + 1"
	          :disabled="formState.path.length === 1"
	          @click="addPath()"
	        />
	        <MinusCircleOutlined
	          v-if="formState.path.length > 1"
	          :disabled="formState.path.length === 1"
	          @click="removePath(item)"
	        />
	      </a-space>
	    </a-form-item>
	</a-form-item>
    <!-- 其他表单项 -->
	
	<a-form-item 
      name="type" 
      label="是否开启" 
      :rules="[{ required: true, message: '请选择', trigger: 'blur' }]"
    >
      <a-radio-group 
        v-model:value="formState.type" 
        @change="handleChangeType">
        <a-radio :value="2"></a-radio>
        <a-radio :value="1"></a-radio>
      </a-radio-group>
    </a-form-item>
        
    <a-form-item>
      <a-button type="primary" @click="handleSubmit">
        Submit
      </a-button>
    </a-form-item>
  </a-form>
</template>

<script lang="ts" setup>
import { MinusCircleOutlined, PlusCircleOutlined, QuestionCircleOutlined } from '@ant-design/icons-vue'

const formRef = ref<FormInstance | any>()
const formState = ref({ 
	path: [{value: ''}],
	type: 1
})

const removePath = (item: any) => {
  const index = props.formState.path.indexOf(item)
  if (index !== -1) {
    props.formState.path.splice(index, 1)
  }
}
const addPath = () => {
  props.formState.path.push({
    value: ''
  })
}

const validateUri = async (_rule: any, value: string) => {
  if (!/^(\*|\/\*|\/)/.test(value)) {
    return Promise.reject('path 需要以“*”、“/*”、“/”开始,不能包含特殊字符')
  } else {
    return Promise.resolve()
  }
}

function handleSubmit() {
  formRef.value && (formRef.value).validate().then((res: any) => {
    // todo
  });
}
</script>

到此,一个数组下的表单校验开发就完成了。

如何单独只对数组校验,或者数组中某一个校验

上面 formRef.value.validate() 是通过 ref 对整个表单的校验,那么如果我只是想实现单个校验呢?

function handleChangeType () {
  formRef.value && (formRef.value).validate(['mobile', 'captcha'])
}

但是针对对:name=“”这种数组方式,如何处理呢?

百度查询了很多,Chatgpt也尝试了:

// 错误方式:
function handleChangeType () {
	formRef.value && (formRef.value).validate(['path[0].value', 'path[1].value']) // 无反应
}

但是,这些都是错误的,并没有生效,真正生效的是下面这个:

// 正确方式
function handleChangeType () {
	// 对数据中的某个数据校验
	formRef.value && (formRef.value).validate([['path', 0, 'value'], ['path', 1, 'value']])
	// 对数据所有数据校验
    const regxPaths = formState.value.path.map((item:any, index:number) => ['path', index, 'value'])
    formRef.value && (formRef.value).validate(regxPaths)
}

文章到此结束,希望对你有所帮助!

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

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

相关文章

vue3组件之间的传参

1、父传子 defineProps 父组件 <script setup>import { reactive } from vue;import Children from ./children.vue;const parentProps reactive({name:zhangsan,age:20})</script><template><div>这是父组件</div><div>子组件:<Chil…

空间数据索引的利器:R-Tree原理与实现深度解析

空间数据索引的利器&#xff1a;R-Tree原理与实现深度解析 R-Tree的原理插入操作分裂操作查询操作 R-Tree的伪代码R-Tree的C语言实现讨论结论 R-Tree是一种平衡树&#xff0c;用于空间数据索引&#xff0c;特别是在二维或更高维度的几何对象存储和检索中。它由Antony Guttman和…

万益蓝Wonderlab益生菌:吃雪糕的自由,我终于找回来了!

虽然现在不是夏天&#xff0c;但是我必须要来说一下&#xff01;我不仅在夏天可以吃雪糕&#xff01;冬天吃也完全没有问题&#xff01; 夏天&#xff0c;对于很多人来说&#xff0c;是雪糕、冷饮和冰镇西瓜的代名词。但对于我&#xff0c;这简直就是个“禁区”。每次看着别人…

ACS510-01-157A-4 3ABD00015756-D通用变频器

商业别名:ACS510-01-157A-4 产品ID:3ABD00015756-D ABB型号名称:ACS510-01-157A-4 目录说明:ACS510-01-157A-4,157A,380V,IP21 详细描述:ACS510-01-157A-4,157A,380V,IP21 原产地:China (CN) 海关关税号:85044099 发票说明:ACS510-01-157A-4,157A,380V,IP21 按订单生产:No 最小…

农业四情监测系统:科技助力农业智慧化

【MQ-4NYSQ】农业四情监测系统&#xff0c;依托农业物联网环境传感器&#xff0c;精准捕捉苗田苗情、土壤墒情、苗田灾情以及苗田病虫草情&#xff0c;为现代农业生产提供了有力支持。 传统的苗情监测往往依赖人工手动记录与上报&#xff0c;这种方式不仅效率低下&#xff0c;…

【深度学习实战(8)】如何绘制loss曲线图

一、步骤 我们先定义一个dict&#xff0c;每一个key对应的value都是一个list。 loss_history dict((k, []) for k in ["epoch", "train_loss", "val_loss"])每一轮或者每一次迭代的损失都通过list记录下来。 loss_history["epoch"…

Task01:初识深度学习

学习视频&#xff1a; 深度学习介绍_哔哩哔哩_bilibili 03 安装【动手学深度学习v2】_哔哩哔哩_bilibili 02 深度学习介绍【动手学深度学习v2】 x轴&#xff1a;不同的模式 y轴&#xff1a;“我”想做的东西 计算机视觉中是像素&#xff0c;很难用符号表示&#xff0c;所以…

Meta通过开源Llama 3 LLM提高了标准

Meta 推出了 Llama 3,这是其最先进的开源大型语言模型(LLM)的下一代产品。这家科技巨头声称,Llama 3 在现实场景中建立了新的性能基准,超越了之前行业领先的模型,如 GPT-3.5。 Meta 在一篇博文中宣布了这一发布,并表示:"通过 Llama 3,我们致力于打造与当今最好的专有模型…

qt实现不定数量的按钮向前向后移动展示

按钮模拟移动 引言示例代码第一种思路开发环境代码结构实现代码第二种思路开发环境实现代码第三种思路开发环境实现代码总结引言 此文主要记录用qt实现按钮的移动,具体效果如下: 模拟按钮移动效果 示例代码 本文记录了三种实现方式。 第一种 思路 用动态数组vector存放创…

系统调优助手,PyTorch Profiler TensorBoard 插件教程

0x1. 前言 使用PyTorch Profiler进行性能分析已经一段时间了&#xff0c;毕竟是PyTorch提供的原生profile工具&#xff0c;个人感觉做系统性能分析时感觉比Nsys更方便一些&#xff0c;并且画的图也比较直观。这里翻译一下PyTorch Profiler TensorBoard Plugin的教程并分享一些…

边缘计算网关的工业设备数据采集方案-天拓四方

随着工业4.0时代的到来&#xff0c;工业设备数据采集成为了实现智能制造、提升生产效率的关键环节。传统的数据采集方案往往依赖于中心化的数据处理方式&#xff0c;但这种方式在面对海量数据、实时性要求高的工业场景时&#xff0c;往往显得力不从心。因此&#xff0c;利用边缘…

代码+视频,R语言对数据进行多重插补后回归分析

我们在临床做回顾性研究分析中经常要面对数据缺失的问题&#xff0c;如果数据缺失量大就会对我们的研究结果产生影响&#xff0c;近年来&#xff0c;对数据进行多重插补广泛应用于SCI论文中。我们在之前的文章中已经演示了使用SPSS对数据进行多重插补并分析。今天&#xff0c;我…

swiper 去掉轮播图上的小点点 小圆圈(完美解决方案)

文章目录 问题描述解决方案问题复现处理方案 问题描述 大家好&#xff01;我是夏小花&#xff0c;今天是2024年4月22日|农历三月十四&#xff0c;今天这篇博文主要解决swiper 去掉轮播图上的小点点 小圆圈&#xff0c;具体解决方案如下所示 解决方案 问题复现 现在现在可以看…

cox版本的Boruta+SHAP分析(心力衰竭数据集)

Cox版本的BorutaSHAP分析&#xff08;心力衰竭数据集&#xff09; Boruta算法是变量筛选的有力工具&#xff0c;而SHAP分析是观察预测变量与结局变量间关系的不错的方法&#xff0c;在传统的分析方法的基础上提供了一个全新的视角。Boruta算法SHAP分析&#xff0c;正在逐渐成为…

【IT运维入门(ITHW)系列】之「快速部署」第二期清单(持续更新)

ITHW是Information Technology Hello World的缩写简拼。意在提供IT领域的入门相关知识&#xff0c;近期给大家带来的是主流技术选型的快速部署系列&#xff0c;意在最大程度地简化部署过程&#xff0c;以便能快速体验或测试相关技术选型。 「快速部署」第一期清单 ITHW快捷部署…

鸿蒙入门10-CheckBoxGroup组件

复选框群组 用于控制多个复选框全选或者不全选状态 参数 参数形式 &#xff1a; CheckboxGroup( options?: { group?: string } ) 创建复选框群组&#xff0c;可以用于控制群组内的 CheckBox 成员 全选 或者 不全选 相同 group 的 CheckBox 和 CheckBoxGroup 为同一群组 参…

java生成数据库数据到excel当做下拉选择,copy就完事~

背景&#xff1a;由于需要下载模板&#xff0c;模板包含下拉选择框&#xff0c;但是下拉选择框不想手写&#xff0c;并且需要从数据库读取&#xff0c;由于直接设置excel会有单元格最大255个字符长度限制&#xff0c;所以用到以下部分代码。 思路&#xff1a;由于数据模板在sh…

设计专家教你:3步轻松完成导航设计!

为了实现网页或应用程序的高可用性&#xff0c;UI导航是必不可少的。设计UI导航并不容易。UI导航可以根据需要或要求包含任何数量的项目&#xff0c;引导用户与产品互动&#xff0c;实现目标动作或隐藏的设计组合。在设计UI导航时&#xff0c;应注意最终用户的需求&#xff0c;…

前端crypto-js, 文件加密,判断相同文件、图片(MD5,SHA256)

文章目录 前情提要应用场景实战解析最后前情提要 大家好,今天我们来接触一个库crypto-js 没错,上面是有道翻译的截图,为了我们得到的信息更权威,这个库是用来加密的,但介绍是说,已经停止维护,但并不影响我们在前端项目中的使用,所以学学也没有坏处 应用场景 判断图片…

Android集成Sentry实践

需求&#xff1a;之前使用的是tencent的bugly做为崩溃和异常监控&#xff0c;好像是要开始收费了&#xff0c;计划使用开源免费的sentry进行替换。 步骤&#xff1a; 1.修改工程文件 app/build.gradle apply plugin: io.sentry.android.gradle sentry {// 禁用或启用ProGua…