React Ant Design 中内置、自定义表单验证的火速上手

本文主要是介绍React Ant Design 中内置、自定义表单验证的火速上手,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、常见的内置验证规则

在 React Ant Design 中,除了自定义验证规则外,还有一些常见的内置验证规则,包括:

  1. required:

    • 表示该字段是必填的。
  2. min:

    • 用于数字字段,表示最小值。
    • 用于字符串字段,表示最小长度。
  3. max:

    • 用于数字字段,表示最大值。
    • 用于字符串字段,表示最大长度。
  4. email:

    • 验证输入是否为有效的电子邮件地址。
  5. url:

    • 验证输入是否为有效的 URL。
  6. pattern:

    • 使用正则表达式验证输入。
  7. type:

    • 验证输入的数据类型,可选项有 stringnumberbooleanintegerfloat
  8. validator:

    • 使用自定义函数进行验证。可以返回 Promise 以实现异步验证。
  9. whitespace:

    • 验证输入是否只包含空白字符。
  10. len:

    • 验证字符串长度是否等于指定值。

这些内置的验证规则可以帮助您快速实现常见的表单验证需求。您可以根据实际情况,选择合适的规则并组合使用,以满足业务需求。同时,您也可以根据特殊需求,定义自定义的验证规则。

例1: 内置邮箱验证

<Form.Itemname="email"label="Email"rules={[{required: true,message: 'Please input your email!',},{type: 'email',message: 'Please enter a valid email address!',},]}
><Input />
</Form.Item>

为 email 字段添加了两个验证规则:

  1. required 规则确保该字段是必填的。
  2. email 规则验证输入是否为有效的电子邮件地址。
    如果用户输入的内容不符合电子邮件地址的格式,表单验证会失败,并显示错误消息"Please enter a valid email address!"。

例2:len 验证规则
len 规则用于验证字符串长度是否等于指定值。

<Form.Itemname="password"label="Password"rules={[{required: true,message: 'Please input your password!',},{len: 8,message: 'Password must be exactly 8 characters long!',},]}
><Input.Password />
</Form.Item>

为 password 字段添加了两个验证规则:

  1. required 规则确保该字段是必填的。
  2. len 规则验证输入的字符串长度是否等于 8。

如果用户输入的密码长度不是 8 个字符,表单验证会失败,并显示错误消息"Password must be exactly 8 characters long!"。

二、自定义表单验证步骤

  1. 使用自定义表单验证规则:
    • 在表单字段定义中使用 rules 属性指定表单验证规则。
    • 自定义验证规则可以通过 validator 属性来实现。
<Form.Itemname="myField"label="My Field"rules={[{required: true,message: 'Please input your field!',},{validator: (_, value) => {if (value > 10) {return Promise.resolve();}return Promise.reject(new Error('Value must be greater than 10!'));},},]}
><Input />
</Form.Item>
  1. 使用 Form.useForm() 自定义表单:
    • 通过 Form.useForm() 钩子创建一个自定义表单实例。
    • 将表单实例传递给表单组件的 form 属性。
const [form] = Form.useForm();return (<Form form={form} onFinish={onFinish}>{/* 表单项 */}</Form>
);
  1. 使用 validateFields 手动触发表单验证:
    • 通过 form.validateFields() 方法手动触发表单验证。
    • 可以在表单提交或其他特定事件中调用该方法。
const onFinish = async () => {try {await form.validateFields();// 表单验证通过, 执行提交逻辑} catch (errorInfo) {console.log('Failed:', errorInfo);}
};
  1. 使用 form.getFieldsValue() 获取表单数据:
    • 通过 form.getFieldsValue() 方法获取表单当前的值。
    • 在表单提交时可以使用该方法获取表单数据。
const onFinish = () => {const values = form.getFieldsValue();console.log('Received values of form:', values);
};

通过以上步骤,您可以在 React Ant Design 中实现自定义的表单验证逻辑,满足您的业务需求。同时,Ant Design 还提供了其他丰富的表单相关功能,如动态增减表单项、表单联动等,可以根据实际情况进一步探索和应用。

三、完整示例

效果
在这里插入图片描述
下面是一个使用 React Ant Design 实现自定义表单验证的完整示例代码:

import React from 'react';
import { Form, Input, Button } from 'antd';const MyForm = () => {const [form] = Form.useForm();const onFinish = async () => {try {await form.validateFields(); //验证表单const values = form.getFieldsValue(); //获取表单数据console.log('Received values of form:', values);// 提交表单逻辑} catch (errorInfo) {console.log('Failed:', errorInfo);}};return (<Form form={form} onFinish={onFinish}><Form.Itemname="username"label="Username"rules={[{required: true,message: 'Please input your username!',},{min: 3,message: 'Username must be at least 3 characters long!',},{pattern: /^[a-zA-Z0-9]+$/,message: 'Username can only contain letters and numbers!',},]}><Input /></Form.Item><Form.Itemname="password"label="Password"rules={[{required: true,message: 'Please input your password!',},{min: 8,message: 'Password must be at least 8 characters long!',},{pattern: /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[a-zA-Z\d]+$/,message: 'Password must contain at least one uppercase letter, one lowercase letter, and one number!',},]}><Input.Password /></Form.Item><Form.Itemname="email"label="邮箱"rules={[{required: true,message: '请输入邮箱地址',},{type: 'email',message: '邮箱格式不对,请重新输入',},]}><Input /></Form.Item><Form.Item><Button type="primary" htmlType="submit">Submit</Button></Form.Item></Form>);
};export default MyForm;

在这个示例中,我们使用了 Form.useForm() 钩子创建了一个自定义的表单实例,并将其传递给表单组件的 form 属性。

对于用户名字段,我们定义了以下自定义验证规则:

  • 必填
  • 至少 3 个字符
  • 只能包含字母和数字

对于密码字段,我们定义了以下自定义验证规则:

  • 必填
  • 至少 8 个字符,最多12个字符
  • 必须包含至少一个大写字母、一个小写字母和一个数字

在表单提交时,我们使用 form.validateFields() 方法手动触发表单验证。如果验证通过,我们可以获取表单数据并执行提交逻辑。如果验证失败,我们会在控制台打印错误信息。

这个示例展示了如何在 React Ant Design 中实现自定义的表单验证逻辑。您可以根据实际需求,进一步扩展和修改这个示例代码。

这篇关于React Ant Design 中内置、自定义表单验证的火速上手的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/915639

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni