Element UI 一键校验多表单(v-for循环表单,异步校验规则,v-for 中的 ref 属性,避坑 forEach 不支持异步 await )

news2024/12/27 13:33:51

需求描述

  • 表单为数组 v-for 循环得到的多表单,如可自由增删的动态表单
  • 表单中存在异步校验规则,如姓名需访问接口校验是否已存在
  • 点击提交按钮,需一键校验所有表单,仅当所有表单都通过校验,才能最终提交到后台

效果预览

在这里插入图片描述

技术要点

  • 校验规则 rules 可复用,编写一套即可

异步校验规则的写法

let checkName = (rule, value, callback) => {
  axios({
    method: "get",
    url: "https://jsonplaceholder.typicode.com/posts",
    params: {
      userId: value,
    },
  }).then((res) => {
    if (res.data.length) {
      return callback(new Error("已存在"));
    } else {
      return callback();
    }
  });
};

此处的接口是公共的免费接口,仅模拟效果,不必深究传参和返回

formRules: {
  name: [
    { required: true, trigger: "blur", message: "请输入姓名" },
    { validator: checkName, trigger: "blur" },
  ],
},

v-for 中的 ref 属性用静态字符串

通常,若两个元素 ref 属性相同,通过 this.$refs 只能获取到最终的元素

    <p ref="p1">1</p>
    <p ref="p1">2</p>
this.$refs.p1  // 获取到的是 <p>2</p>

但在 v-for 中的 ref ,通过 this.$refs 得到的是一个数组

在这里插入图片描述
所以,此例中,获取第一个表单的方法是

this.$refs.formRef[0]

forEach中使用 await 无效!

forEach 只支持同步,不支持异步
所以此例多表单的校验需改用 for 循环,通过 break 还可提前跳出 for 循环

添加 try catch 捕获 await 中的报错

  • 添加 try catch 可避免控制台报错,同时避免报错阻塞代码的执行,可提升用户体验。
  • 给每一个await 都添加 try catch ,可在 catch 中可获知具体是哪一个表单校验失败!

代码实现

<template>
  <div style="padding: 30px; width: 300px">
    <div v-for="(formData, formIndex) in formList" :key="'form' + formIndex">
      <el-form
        ref="formRef"
        :model="formData"
        :rules="formRules"
        label-width="110px"
        size="mini"
        status-icon
      >
        <el-form-item :label="`表单 ${formIndex + 1} 的姓名`" prop="name">
          <el-input v-model="formData.name" placeholder="请输入"></el-input>
        </el-form-item>
      </el-form>
    </div>

    <el-button @click="submit">提交</el-button>
  </div>
</template>

<script>
import axios from "axios";
export default {
  data() {
    let checkName = (rule, value, callback) => {
      axios({
        method: "get",
        url: "https://jsonplaceholder.typicode.com/posts",
        params: {
          userId: value,
        },
      }).then((res) => {
        if (res.data.length) {
          return callback(new Error("已存在"));
        } else {
          return callback();
        }
      });
    };

    return {
      formList: [{}, {}],
      formRules: {
        name: [
          { required: true, trigger: "blur", message: "请输入姓名" },
          { validator: checkName, trigger: "blur" },
        ],
      },
    };
  },
  methods: {
    async submit() {
      let formRefList = this.$refs.formRef;
      let result = true;

      for (let index = 0; index < this.formList.length; index++) {
        try {
          await formRefList[index].validate();
          console.log(`${index + 1}个表单通过校验`);
        } catch (error) {
          console.log(`${index + 1}个表单校验失败`);
          result = false;
          break;
        }
      }

      if (result) {
        console.log(`所有表单通过校验`);
      } else {
        console.log(`存在表单校验失败`);
      }
    },
  },
};
</script>

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

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

相关文章

大模型应用之路:从提示词到通用人工智能(AGI)

前言 大模型在人工智能领域的应用正迅速扩展&#xff0c;从最初的提示词&#xff08;Prompt&#xff09;工程到追求通用人工智能&#xff08;AGI&#xff09;的宏伟目标&#xff0c;这一旅程充满了挑战与创新。本文将探索大模型在实际应用中的进展&#xff0c;以及它们如何为实…

微服务开发与实战Day07 - MQ高级篇

一、消息可靠性问题 首先&#xff0c;分析一下消息丢失的可能性有哪些。 消息从发送者发送消息&#xff0c;到消费者处理消息&#xff0c;需要经过的流程是这样的&#xff1a; 消息从生产者到消费者的每一步都可能导致消息丢失&#xff1a; 发送消息时丢失&#xff1a; 生产…

【车载AI音视频电脑】200万像素迷你一体机

产品主要特点&#xff1a; -设备安装方便简洁&#xff0c;可通过3M胶直接将设备粘 贴到车前挡风玻璃上 -支持IE预览&#xff0c;手机&#xff0c;PAD实时预览&#xff0c; 支持电脑客 户端实时预览功能 -内置2路模拟高清, 每路均可达到200万像素。另 外可扩充2路1080P模拟…

取证工作: SysTools SQL Log Analyzer, 完整的 SQL Server 日志取证分析

天津鸿萌科贸发展有限公司是 Systools 系列软件的授权代理商。 SysTools SQL Log Analyzer 是 Systools 取证工具系列之一&#xff0c;用于调查 SQL Server 事务日志&#xff0c;以对数据库篡改进行取证分析。 什么是 SQL Server 事务日志&#xff1f; 在深入研究 SQL 事务日…

【Linux文件篇】磁盘到用户空间:Linux文件系统架构全景

W...Y的主页 &#x1f60a; 代码仓库分享 &#x1f495; 前言&#xff1a;我们前面的博客中一直提到的是被进程打开的文件&#xff0c;而系统中不仅仅只有被打开的文件还有很多没被打开的文件。如果没有被打开&#xff0c;那么文件是在哪里进行保存的呢?那我们又如何快速定位…

Vue.js入门教程:轻松掌握前端框架的魔法

随着前端技术的飞速发展&#xff0c;Vue.js凭借其简洁、易上手和高效的特点&#xff0c;成为了前端开发者们的新宠。本文将带你走进Vue.js的世界&#xff0c;从零开始&#xff0c;一步步掌握这个强大的前端框架。 一、什么是Vue.js Vue.js是一款构建用户界面的渐进式JavaScri…

数据结构——栈(Stack)详解

1. 栈&#xff08;Stack&#xff09; 1.1 概念 栈&#xff1a;一种特殊的线性表&#xff0c;只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中数据元素遵循后进先出LIFO(Last In First Out)的原则 压栈&am…

可再生能源的未来——Kompas.ai如何助力绿色发展

引言 在全球气候变化和能源危机的背景下&#xff0c;可再生能源逐渐成为能源发展的重要方向。本文将探讨可再生能源的发展趋势&#xff0c;并介绍Kompas.ai如何通过AI技术助力绿色发展的实现。 可再生能源的发展及其重要性 可再生能源是指通过自然资源产生的能源&#xff0c;…

Zabbix 7.0 新增功能亮点(二)——history.push API方法

Zabbix7.0LTS一经发布便吸引了众多运维小伙伴的关注&#xff0c;乐维社区forum.lwops.cn也伴随着不少小伙伴的热议与探讨&#xff0c;话不多说&#xff0c;抓紧上车。 前面我们介绍了zabbix 7.0 新增功能亮点&#xff08;一&#xff09;——T参数&#xff0c;本篇将向大家介绍z…

2024热门骨传导耳机购买推荐!精选五款好用不贵!

对于很多喜欢运动健身的小伙伴&#xff0c;在现在市面上这么多种类耳机的选择上&#xff0c;对于我来说的话还是很推荐大家去选择骨传导运动耳机的&#xff0c;相较于普通的入耳式蓝牙耳机&#xff0c;骨传导耳机是通过振动来传输声音的&#xff0c;而入耳式耳机则是通过空气传…

webstorm yarn环境配置

1. 安装nodejs https://nodejs.cn/download/ 2. 安装npm npm i yarn -g3.下载并安装webstorm https://www.jetbrains.com/webstorm/ 4. 打开settings确认node和yarn的配置正确5. 打开项目更新包 yarn install

酷开科技丨酷开系统智慧中心,解锁AI智能家居生活的无限可能

想象一下&#xff0c;未来的AI电视不再是冷冰冰的机器&#xff0c;而是家庭的智能伙伴。它学习你的喜好&#xff0c;预测你的需求&#xff0c;用声音和触感与你交流。它控制家中的灯光、温度&#xff0c;甚至帮你订购生活用品。 在探索智能家居的未来发展时&#xff0c;酷开系…

Rust 实战丨倒排索引

引言 倒排索引&#xff08;Inverted Index&#xff09;是一种索引数据结构&#xff0c;用于存储某个单词&#xff08;词项&#xff09;在一组文档中的所有出现情况的映射。它是搜索引擎执行快速全文搜索的核心技术&#xff0c;也广泛用于数据库中进行文本搜索。我们熟知的 Ela…

SpringBoot 大文件基于md5实现分片上传、断点续传、秒传

SpringBoot 大文件基于md5实现分片上传、断点续传、秒传 SpringBoot 大文件基于md5实现分片上传、断点续传、秒传前言1. 基本概念1.1 分片上传1.2 断点续传1.3 秒传1.4 分片上传的实现 2. 分片上传前端实现2.1 什么是WebUploader&#xff1f;功能特点接口说明事件APIHook 机制 …

休闲零食连锁迎来“万店”时代!“鸣鸣很忙”快速扩张有何秘诀?

6月12日&#xff0c;零食很忙与赵一鸣零食合并后的集团名称正式变更为“鸣鸣很忙”集团。目前&#xff0c;该集团旗下的双品牌全国门店总数已经突破10000家&#xff0c;标志着休闲零食连锁行业正式迎来“万店”时代。在激烈的市场竞争中&#xff0c;“鸣鸣很忙”以全国门店数第…

【Numpy】一文向您详细介绍 np.abs()

【Numpy】一文向您详细介绍 np.abs() 下滑即可查看博客内容 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地&#xff01;&#x1f387; &#x1f393; 博主简介&#xff1a;985高校的普通本硕&#xff0c;曾…

rsa加签验签C#和js以及java互通

js实现rsa加签验签 https://github.com/kjur/jsrsasign 11.1.0版本 解压选择需要的版本&#xff0c;这里选择all版本了 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>JS RSA加签验签</title&g…

【Altium】AD-Fill、Region、Polygon之间的区别

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 Fill、Polygon、Region介绍&#xff0c;了解三者的区别。 2、 知识点 正片层、负片层&#xff0c;以及AD叠层管理中的设置。 3、软硬件环境 1&#xff09;、无关 2&#xff09;、无关 3&#xff09;、无关 4、…

动作识别综合指南

本文将概述当前动作识别&#xff08;action recognition&#xff09;的方法和途径。 为了展示动作识别任务的复杂性&#xff0c;我想举这个例子&#xff1a; 你能明白我在这里做什么吗&#xff1f;我想不能。至少你不会确定答案。我正在钻孔。 你能弄清楚我接下来要做什么吗&…

10. 安全性

这里写自定义目录标题 第10章 安全性10.1 安全性通用场景10.2 安全性策略不安全状态避免替代预测模型 不安全状态检测超时时间戳条件监测健全性检查比较 抑制冗余限制后果屏障 恢复 10.3基于策略的安全问卷10.4 安全性的模式10.5 扩展阅读10.6 问题讨论 第10章 安全性 吉尔斯&a…