React 入门第五天:高效处理表单与表单验证

本文主要是介绍React 入门第五天:高效处理表单与表单验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学习React的第五天,我深入研究了React中的表单处理和表单验证。作为前端开发的核心技能之一,表单处理是我们日常开发中无法避免的任务。虽然在Vue中,我们也会频繁地与表单打交道,但React的表单处理方式与Vue有些不同,这也是我学习的重点之一。

1. React中表单处理的基础

React中表单处理的核心在于受控组件与非受控组件的概念。所谓受控组件,是指组件的状态由React来控制,其输入值也由React的状态进行管理。与之相对的,非受控组件则直接依赖DOM自身的状态。

受控组件的实现

在受控组件中,表单元素的值会被存储在组件的state中,并通过事件处理函数来更新state。以下是一个简单的受控组件示例:

import React, { useState } from 'react';function Form() {const [name, setName] = useState('');const handleChange = (event) => {setName(event.target.value);};const handleSubmit = (event) => {event.preventDefault();alert('提交的名字: ' + name);};return (<form onSubmit={handleSubmit}><label>名字:<input type="text" value={name} onChange={handleChange} /></label><button type="submit">提交</button></form>);
}export default Form;

在这个例子中,input元素的值由name这个state变量控制,onChange事件处理函数会在用户输入时更新state。表单的提交操作则通过onSubmit事件处理函数进行处理。

非受控组件的使用

相比受控组件,非受控组件直接使用ref来获取DOM元素的值。非受控组件通常用于快速实现某些简单表单,不需要过多的state管理。

import React, { useRef } from 'react';function Form() {const nameInput = useRef(null);const handleSubmit = (event) => {event.preventDefault();alert('提交的名字: ' + nameInput.current.value);};return (<form onSubmit={handleSubmit}><label>名字:<input type="text" ref={nameInput} /></label><button type="submit">提交</button></form>);
}export default Form;

在这个例子中,ref用于直接访问DOM元素并获取其值,而无需借助React的state管理。

2. 表单验证的实现

表单验证是确保用户输入数据符合预期的重要步骤。在React中,可以通过多种方式实现表单验证,包括手动编写验证逻辑或使用第三方库。

简单的表单验证

以下是一个简单的手动验证示例,用户提交表单前会检查输入是否为空:

function Form() {const [name, setName] = useState('');const [error, setError] = useState('');const handleChange = (event) => {setName(event.target.value);};const handleSubmit = (event) => {event.preventDefault();if (name === '') {setError('名字不能为空');} else {setError('');alert('提交的名字: ' + name);}};return (<form onSubmit={handleSubmit}><label>名字:<input type="text" value={name} onChange={handleChange} /></label>{error && <p style={{ color: 'red' }}>{error}</p>}<button type="submit">提交</button></form>);
}

这个示例中,我们通过error状态变量来跟踪错误信息,并在表单中动态展示验证结果。

使用第三方库进行表单验证

为了更简洁和功能更强大,可以使用Formik和Yup这样的第三方库来处理复杂的表单验证。

import React from 'react';
import { useFormik } from 'formik';
import * as Yup from 'yup';function Form() {const formik = useFormik({initialValues: {name: '',},validationSchema: Yup.object({name: Yup.string().required('名字不能为空'),}),onSubmit: (values) => {alert('提交的名字: ' + values.name);},});return (<form onSubmit={formik.handleSubmit}><label>名字:<inputtype="text"name="name"onChange={formik.handleChange}value={formik.values.name}/></label>{formik.errors.name ? <p style={{ color: 'red' }}>{formik.errors.name}</p> : null}<button type="submit">提交</button></form>);
}export default Form;

使用Formik和Yup,我们可以非常简洁地定义表单验证规则,并让Formik自动管理表单状态和验证逻辑。这种方式非常适合处理复杂的表单。

3. 小结与展望

通过学习React中的表单处理和验证,我感受到了React的灵活性和强大。受控组件与非受控组件的概念让我在表单处理时有了更多选择,而通过手动验证与第三方库的对比,我更好地理解了不同场景下的最佳实践。

接下来,我计划继续深入React的生态系统,探索状态管理工具如Redux,进一步提升我在React开发中的能力。

这篇关于React 入门第五天:高效处理表单与表单验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

高效+灵活,万博智云全球发布AWS无代理跨云容灾方案!

摘要 近日,万博智云推出了基于AWS的无代理跨云容灾解决方案,并与拉丁美洲,中东,亚洲的合作伙伴面向全球开展了联合发布。这一方案以AWS应用环境为基础,将HyperBDR平台的高效、灵活和成本效益优势与无代理功能相结合,为全球企业带来实现了更便捷、经济的数据保护。 一、全球联合发布 9月2日,万博智云CEO Michael Wong在线上平台发布AWS无代理跨云容灾解决方案的阐述视频,介绍了

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只