vue3 + Ant design vue formItem 无法使用嵌套的form表单校验

embedded/2024/10/21 11:33:14/

文章目录

  • 前言
  • 一、背景`在这里插入代码片`
  • 二、操作步骤
    • 1.复现前的准备工作
      • (1)vue版本和ant design vue 版本
      • (2)任意页面的代码
    • 2.解决问题
    • 3.自定义表单校验的代码
  • 总结


前言

提示:


一、背景在这里插入代码片

  • 背景:
    • Ant design vue + vue3的项目,后端的数据格式为对象套对象,绑定数据的时候发现,第二次的formItem表单校验没有效果,出现以下问题:
    • 理想场景:输入一部分的必填项,点击确定,表单校验不通过的提示,不请求接口及其后续操作。
    • 实际场景:输入一部分的必填项,点击确定,直接请求新增/编辑接口,然后跳转页面。
  • 技术定位:初级

二、操作步骤

1.复现前的准备工作

(1)vue版本和ant design vue 版本

javascript">"ant-design-vue": "^3.2.20",
"vue": "^3.2.33",

(2)任意页面的代码

如下面代码示例, 对象password.ps1使用表单校验,没有输入任何数据,表单校验仍然通过了

<template><div>{{ formState }}</div><Form :model="formState" name="basic" autocomplete="off" @finish="onFinish" @finishFailed="onFinishFailed"><FormItem label="Username" name="username" :rules="[{ required: true, message: 'Please input your username!' }]"><Input v-model:value="formState.username" /></FormItem><FormItem label="Password" name="password.ps1":rules="[{ required: true, message: 'Please input your username!' }]"><InputPassword v-model:value="formState.password.ps1" /></FormItem> {{ formState.password.ps1 }}<FormItem :wrapper-col="{ offset: 8, span: 16 }"><Button type="primary" html-type="submit">Submit</Button></FormItem></Form>
</template>
<script lang="ts" setup>
import { reactive } from 'vue'
import { Form, FormItem, Input, InputPassword, Button } from 'ant-design-vue'
import type { Rule } from 'ant-design-vue/es/form';
interface objpasType {ps1: string,ps2: string,
}
interface FormStateType {username: string;password: objpasType;remember: boolean;
}
const rules: Record<string, Rule[]> = {username: [{ required: true, message: '请输入', trigger: 'change' }],'password.ps1': [{ required: true, message: '请输入', trigger: 'change' }],
}
const formState = reactive<FormStateType>({username: '',password: {ps1: '',ps2: '',},remember: true,
});
const onFinish = (values: any) => {console.log('Success:', values);
};const onFinishFailed = (errorInfo: any) => {console.log('Failed:', errorInfo);
};
</script>

2.解决问题

当我们使用自定义表单校验后,虽然values里面的值依旧为空,但是通过了表单校验
在这里插入图片描述

3.自定义表单校验的代码

javascript"><template><div>{{ formState }}</div><Form :model="formState" name="basic" autocomplete="off" @finish="onFinish" @finishFailed="onFinishFailed"><FormItem label="Username" name="username" :rules="[{ required: true, message: 'Please input your username!' }]"><Input v-model:value="formState.username" /></FormItem><FormItem label="Password" name="password.ps1":rules="[{ required: true, validator: (rules) => checkSchedulingCycle(rules, formState.password.ps1), }]"><InputPassword v-model:value="formState.password.ps1" /></FormItem> {{ formState.password.ps1 }}<FormItem :wrapper-col="{ offset: 8, span: 16 }"><Button type="primary" html-type="submit">Submit</Button></FormItem></Form>
</template>
<script lang="ts" setup>
import { reactive } from 'vue'
import { Form, FormItem, Input, InputPassword, Button } from 'ant-design-vue'
import type { Rule } from 'ant-design-vue/es/form';
interface objpasType {ps1: string,ps2: string,
}
interface FormStateType {username: string;password: objpasType;remember: boolean;
}
// const rules: Record<string, Rule[]> = {
//   username: [{ required: true, message: '请输入', trigger: 'change' }],
//   'password.ps1': [{ required: true, message: '请输入', trigger: 'change' }],
// }
const checkSchedulingCycle = async (_rule: Rule, value: any) => {console.log('rules', value)if (!value) return Promise.reject('ps1不能为空');return Promise.resolve();
};
const formState = reactive<FormStateType>({username: '',password: {ps1: '',ps2: '',},remember: true,
});
const onFinish = (values: any) => {console.log('Success:', values);
};const onFinishFailed = (errorInfo: any) => {console.log('Failed:', errorInfo);
};
</script>

总结

ant design vue 不支持嵌套表格的表单校验,只能使用自定义表单校验


http://www.ppmy.cn/embedded/123313.html

相关文章

基于Node.js+Express+MySQL+VUE科研成果网站发布查看科研信息科研成果论文下载免费安装部署

目录 1.技术选型‌ ‌2.功能设计‌ ‌3.系统架构‌ ‌4.开发流程‌ 5.开发背景 6.开发目标 7.技术可行性 8.功能可行性 8.1功能图 8.2 界面设计 8.3 部分代码 构建一个基于Spring Boot、Java Web、J2EE、MySQL数据库以及Vue前后端分离的科研成果网站&#xff0c;可…

新高考的五大变化‌‌(AI生成)

新高考的五大变化‌‌1 考试科目和考试时间的变化 ‌考试科目‌&#xff1a; 改革前&#xff0c;考试科目为‌语文、‌数学&#xff08;文/理&#xff09;、‌外语、‌理科综合/文科综合。 改革后&#xff0c;实行“312”模式&#xff0c;即全国统考科目3门&#…

Pikachu-Sql Inject-搜索型注入

MySQL的搜索语句&#xff1a; select * from table where column like %text%&#xff1b; 如&#xff1a;使用引号闭合左边的引号&#xff0c; or 11 把所有数据查询出来&#xff1b; # 注释掉后面的 引号等&#xff1b; test or 11# 查询出结果&#xff1a; 注入的核心点…

DBT hook 实战教程

本文将介绍dbt中在模型和seed级别使用post-hook的几个具体示例。dbt中的Post-hooks是一个强大而简单的特性&#xff0c;它在构建模型之后(如果是pre-hook&#xff0c;甚至在此之前)执行SQL语句。这些语句实际上(几乎)可以是任何东西&#xff0c;从将表复制到另一个数据库/模式&…

React 组件命名规范

在 React 项目中&#xff0c;如果希望保持组件命名的一致性&#xff0c;并防止在引入时出现不同名称的问题&#xff0c;可以遵循以下的组件规范&#xff1a; 1、默认导出组件&#xff1a; 所有特殊要求的组件&#xff08;如页面组件或根组件&#xff09;应该使用 export defau…

【bash】将本地未合入 master 的分支,生成对应 patche 文件

创建一个 gen-patches.sh 文件 输入以下脚本内容 #!bin/bashif [ $# -ne 1 ]; thenecho "Please input directory name."echo "Usage: "echo "\033[33m $0 <directory> \033[0m"exit 1 fiOUTPUT_DIR"$(pwd)/patches"mkdir…

【mod分享】极品飞车12无间风云高清重置mod,车模重构和材质贴图高清化

大家好&#xff0c;今天我要继续分享一款mod&#xff0c;这款mod是高清重置了极品飞车12无间风云。主要是修改了光晕&#xff0c;替换了很多原始车辆并且对它们进行高清化&#xff0c;同时还是高清化了赛道和部分建筑物&#xff0c;如果你是极品飞车12无间风云的粉丝&#xff0…

基于SpringBoot+Vue的科研课题项目管理系统源码

文章目录 1.技术架构2.主要功能3.获取方式 1.技术架构 后端&#xff1a;SpringBoot 前端&#xff1a;Vue – Element UI 2.主要功能 登录 /注销、 用户管理、项目管理、申报管理、变更管理、 结题管理、角色管理、权限管理、数据字典等功能 3.获取方式 点击下方名片&a…