前端开发 vue 中如何实现 u-form 多个form表单同时校验

在 Vue 项目中使用 UView UI 的 u-form 组件时,多个表单同时校验的需求非常常见。例如,当我们有多个表单需要在同一个页面中进行校验并提交时,我们需要确保每个表单都能进行单独验证,同时可以在同一时刻进行批量验证。

接下来,我们结合实际项目的代码,讲解如何使用 u-form 组件实现多个表单同时校验。

1. 项目背景

假设你有一个页面,需要用户同时填写用户信息和公司信息两个表单。用户信息包括姓名和年龄,公司的信息包括公司名和职位。你希望在用户点击提交按钮时,能够同时校验这两个表单,确保每个表单的数据都符合要求。

2. 代码示例

2.1 页面模板
<template>
  <view>
    <!-- 用户信息表单 -->
    <u-form :model="userForm" ref="userForm" @submit="submitForms">
      <u-form-item label="姓名" prop="name" :rules="nameRules">
        <u-input v-model="userForm.name" placeholder="请输入姓名" />
      </u-form-item>
      <u-form-item label="年龄" prop="age" :rules="ageRules">
        <u-input type="number" v-model="userForm.age" placeholder="请输入年龄" />
      </u-form-item>
      <u-form-item>
        <u-button type="primary" block formType="submit">提交用户信息</u-button>
      </u-form-item>
    </u-form>

    <!-- 公司信息表单 -->
    <u-form :model="companyForm" ref="companyForm" @submit="submitForms">
      <u-form-item label="公司名称" prop="companyName" :rules="companyNameRules">
        <u-input v-model="companyForm.companyName" placeholder="请输入公司名称" />
      </u-form-item>
      <u-form-item label="职位" prop="position" :rules="positionRules">
        <u-input v-model="companyForm.position" placeholder="请输入职位" />
      </u-form-item>
      <u-form-item>
        <u-button type="primary" block formType="submit">提交公司信息</u-button>
      </u-form-item>
    </u-form>

    <!-- 提交按钮 -->
    <u-button type="success" block @click="submitForms">提交所有信息</u-button>
  </view>
</template>
2.2 页面脚本
<script>
export default {
  data() {
    return {
      // 用户信息表单的数据
      userForm: {
        name: '',
        age: ''
      },
      // 用户信息表单的校验规则
      nameRules: [
        { required: true, message: '姓名是必填的', trigger: 'blur' }
      ],
      ageRules: [
        { required: true, message: '年龄是必填的', trigger: 'blur' },
        { type: 'number', message: '请输入有效的年龄', trigger: 'blur' }
      ],

      // 公司信息表单的数据
      companyForm: {
        companyName: '',
        position: ''
      },
      // 公司信息表单的校验规则
      companyNameRules: [
        { required: true, message: '公司名称是必填的', trigger: 'blur' }
      ],
      positionRules: [
        { required: true, message: '职位是必填的', trigger: 'blur' }
      ]
    };
  },
  methods: {
    // 提交表单
    submitForms() {
      // 同时校验所有表单
      const userFormValidation = this.$refs.userForm.validate();
      const companyFormValidation = this.$refs.companyForm.validate();

      // 使用 Promise.all 来并行验证多个表单
      Promise.all([userFormValidation, companyFormValidation])
        .then(() => {
          // 如果所有表单验证通过
          this.$u.toast('所有表单验证通过,提交成功');
          // 可以在这里进行数据提交
        })
        .catch(() => {
          // 如果有任何表单验证失败
          this.$u.toast('表单验证失败,请检查输入');
        });
    }
  }
};
</script>

3. 详细说明

3.1 表单组件使用
  1. u-form:这是 UView UI 中的表单组件。每个表单组件通过 :model 绑定对应的数据对象,通过 ref 设置引用名,以便在 JavaScript 中获取并调用表单的验证方法。

  2. u-form-item:每个表单项。它用来包装一个表单字段,并且通过 prop 来指定字段名称,用来与表单数据进行绑定。

  3. u-input:用于输入数据的组件。它通过 v-model 来双向绑定数据。

3.2 校验逻辑
  1. 表单校验规则:每个表单项都有相应的校验规则(rules)。这些规则确保字段的输入符合预期。在此示例中,我们使用了必填和类型检查(如 number 类型)的规则。

  2. validate 方法:每个 u-form 组件都有一个 validate 方法,它会触发表单的校验并返回一个 Promise。如果表单验证成功,Promise 会成功解析;如果验证失败,Promise 会被拒绝。

3.3 提交和批量校验
  1. submitForms 方法:这是页面的提交处理方法。在该方法中,我们使用了 this.$refs.userForm.validate()this.$refs.companyForm.validate() 来分别触发两个表单的校验,并通过 Promise.all 来并行校验这两个表单。

  2. Promise.all:我们将两个表单的校验 Promise 包装到 Promise.all 中。这样,两个表单的校验会同时进行。当所有表单验证都成功时,then 方法被触发;如果有任何一个表单验证失败,catch 方法会被触发。

  3. this.$u.toast:用来显示提示消息,通知用户是否提交成功或失败。

4. 关键点总结

  • 使用 ref 引用多个表单,方便访问每个表单实例。
  • 通过 this.$refs.form.validate() 触发表单校验。
  • 使用 Promise.all 来并行校验多个表单,确保所有表单的验证同时进行。
  • 利用 validate 返回的 Promise 来处理校验成功与失败的逻辑。

5. 实际项目中的应用场景

在实际项目中,可能会有以下场景需要处理多个表单的验证:

  • 多步骤表单:用户在不同的步骤中填写不同的表单,在提交时需要同时验证所有步骤的表单。
  • 用户与公司信息:用户需要在同一页面提交多个表单(例如,个人信息和公司信息),而且这些表单有不同的校验规则。
  • 动态表单:根据不同的用户选择,动态展示多个表单项,最后进行一次统一的验证。

通过使用 u-form 的并行校验方法,可以方便地实现这些需求,提高用户体验和开发效率。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【漫话机器学习系列】039.点积(dot product)

点积&#xff08;Dot Product&#xff09; 点积是线性代数中的一种基本运算&#xff0c;用于两个向量的操作。它是将两个向量按分量相乘并求和的结果&#xff0c;用于衡量两个向量在同一方向上的相似性。 点积的定义 给定两个相同维度的向量 和 &#xff0c;它们的点积定义为…

2024年大型语言模型(LLMs)的发展回顾

2024年对大型语言模型&#xff08;LLMs&#xff09;来说是充满变革的一年。以下是对过去一年中LLMs领域的关键进展和主题的总结。 GPT-4的壁垒被打破 去年&#xff0c;我们还在讨论如何构建超越GPT-4的模型。如今&#xff0c;已有18个组织拥有在Chatbot Arena排行榜上超越原…

Visual Studio 2022 C++ gRPC 环境搭建

文章目录 1、gRPC 安装2、创建项目2.1、创建 “空的解决方案”2.2、新建 gRPCServer 和 gRPCClient 项目2.3、创建 proto 文件 2、为 gRPC 服务端和客服端项目配置 protobuf 编译2.1、protobuf 配置2.2、gRPCServer 项目配置2.3、gRPCClient 项目配置 3、测试3.1、启动服务端程…

Wasm是什么

WebAssembly 是什么&#xff1f; 1.1 WebAssembly 的定义 WebAssembly&#xff08;简称 Wasm&#xff09;是一种二进制指令格式&#xff0c;设计用于在现代 Web 浏览器中高效运行程序。它可以被认为是一种低级的、接近硬件的编程语言&#xff0c;是一种介于字节码和机器码之间…

使用深度学习来实现图像超分辨率 综述!

今天给大家介绍一篇图像超分辨率邻域的综述&#xff0c;这篇综述总结了图像超分辨率领域的几方面&#xff1a;problem settings、数据集、performance metrics、SR方法、特定领域应用以结构组件形式&#xff0c;同时&#xff0c;总结超分方法的优点与限制。讨论了存在的问题和挑…

直播预告|StarRocks 3.4,打造 AI 时代的智能数据基座,应用场景全面扩展

随着新年的到来&#xff0c;StarRocks 3.4 即将上线&#xff0c;为 AI Workload 和更多应用场景提供强大支持&#xff01;此次升级聚焦于提升 AI 场景支持&#xff0c;并扩展更多应用场景&#xff0c;全方位提升数据分析体验。 更强的 AI 场景支持&#xff1a; 引入 Vector In…

【GOOD】A Survey of Deep Graph Learning under Distribution Shifts

深度图学习在分布偏移下的综述&#xff1a;从图的分布外泛化到自适应 Northwestern University, USA Repository Abstract 图上的分布变化——训练和使用图机器学习模型之间的数据分布差异——在现实世界中普遍存在&#xff0c;并且通常不可避免。这些变化可能会严重恶化模…

【微服务】5、服务保护 Sentinel

Sentinel学习内容概述 Sentinel简介与结构 Sentinel是Spring Cloud Alibaba的组件&#xff0c;由阿里巴巴开源&#xff0c;用于服务流量控制和保护。其内部核心库&#xff08;客户端&#xff09;包含限流、熔断等功能&#xff0c;微服务引入该库后只需配置规则。规则配置方式有…

神经网络的进展与挫折

神经网络的概念可追溯到上世纪40年代,当时被认为是一种模拟大脑神经元网络的计算系统。 1940年代,麦卡洛克(McCulloch)和沃尔特皮茨(Walter Pitts)率先提出了受人类大脑和生物神经网络启发的人工神经网络。 1951年,马文明斯基(Marvin Minsky)的SNARC系统标志着第一个…

搭建企业AI助理的创新应用与案例分析

在大健康零售行业&#xff0c;企业面临着日益增长的市场需求和复杂的供应链管理挑战。AI助理的应用不仅能够提升客户服务效率&#xff0c;还能优化供应链管理&#xff0c;降低运营成本。 一、AI助理在大健康零售行业的创新应用 个性化健康咨询 AI助理可以通过分析客户的健康…

一文读懂「LoRA」:大型语言模型的低秩适应

LoRA: Low-Rank Adaptation of Large Language Models 前言 LoRA作为大模型的微调框架十分实用&#xff0c;在LoRA出现以前本人都是通过手动修改参数、优化器或者层数来“炼丹”的&#xff0c;具有极大的盲目性&#xff0c;但是LoRA技术能够快速微调参数&#xff0c;如果LoRA…

接口项目操作图-thinkphp6-rabbitmq

一、用户开户流程 用户首次需要联系商务开通账户&#xff0c;需要提供手机号及来访问的IP。开好户之后&#xff0c;平台方将提供用户访问的key值及header头部参数的公钥加密文件、body访问参数以及返回数据的公私钥加解密文件。 二、用户请求流程 用户将拿到的key值进行rsa公钥…

程序环境及预处理

一.程序的翻译环境和执行环境 在ANSI C&#xff08;标准c&#xff09;的任何一种实现中&#xff0c;存在两个不同的环境。 计算机是能够执行二进制指令的&#xff0c;但是我们写出的c语言代码是文本信息&#xff0c;计算机不能直接理解 第1种是翻译环境&#xff0c;在这个环境…

回顾 Tableau 2024 亮点功能,助力 2025 数据分析新突破

2024 年&#xff0c;Tableau 用更智能、更高效的工具&#xff0c;重新定义了数据分析的可能性。 回顾 2024 年&#xff0c;Tableau 凭借一系列创新功能&#xff0c;在数据可视化与分析领域再次引领潮流。无论是深度整合 AI 技术&#xff0c;还是优化用户体验的细节&#xff0c;…

【姿态估计实战】使用OpenCV和Mediapipe构建锻炼跟踪器【附完整源码与详细说明】

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

快速上手Python,制作趣味猜数字游戏

在编程学习的旅程中&#xff0c;游戏是一个极佳的切入点。今天&#xff0c;我们将一起创建一个简单而有趣的猜数字游戏&#xff0c;借此机会深入学习Python编程的基础知识和一些实用的编程技巧。无论你是初学者还是有一定基础的开发者&#xff0c;相信你都能从中获得乐趣和收获…

AI驱动的可演化架构与前端开发效率

1. 引言 在当今快节奏的数字时代&#xff0c;软件系统需要具备强大的适应能力才能在瞬息万变的市场需求中保持竞争力。软件可演化架构的重要性日益凸显&#xff0c;它能够让软件系统在面对需求变更、技术升级以及市场波动时&#xff0c;能够快速、高效地进行调整和升级&#x…

用豆包MarsCode IDE打造精美数据大屏:从零开始的指南

原标题&#xff1a;用豆包MarsCode IDE&#xff0c;从0到1画出精美数据大屏&#xff01; 豆包MarsCode IDE 是一个云端 AI IDE 平台&#xff0c;通过内置的 AI 编程助手&#xff0c;开箱即用的开发环境&#xff0c;可以帮助开发者更专注于各类项目的开发。 作为一名前端开发工…

基于RK3568/RK3588大车360度环视影像主动安全行车辅助系统解决方案,支持ADAS/DMS

产品设计初衷 HS-P2-2D是一款针对大车盲区开发的360度全景影像 安全行车辅助系统&#xff0c;通过车身四周安装的超广角像机&#xff0c;经算法合成全景鸟瞰图&#xff0c;通过鸟瞰图&#xff0c;司机非常清楚的看清楚车辆四周情况&#xff0c;大大降低盲区引发的交通事故。 产…

pygame飞机大战

飞机大战 1.main类2.配置类3.游戏主类4.游戏资源类5.资源下载6.游戏效果 1.main类 启动游戏。 from MainWindow import MainWindow if __name__ __main__:appMainWindow()app.run()2.配置类 该类主要存放游戏的各种设置参数。 #窗口尺寸 #窗口尺寸 import random import p…