0

0

初级水平:在 React 中管理表单

WBOY

WBOY

发布时间:2024-07-17 09:22:38

|

984人浏览过

|

来源于dev.to

转载

初级水平:在 react 中管理表单

管理表单是开发 react 应用程序的一个基本方面。本指南将帮助您了解如何处理带有状态的表单数据、如何使用不受控制的组件的引用、执行表单验证以及管理复杂的表单,包括多步骤表单和文件上传。

受控组件

受控组件是由组件状态处理表单数据的组件。这种方法确保 react 组件完全控制表单输入,从而实现更可预测和更易于管理的表单行为。

使用状态处理表单数据

要创建受控组件,您需要为表单数据设置状态并根据用户输入更新状态。

示例:

import react, { usestate } from 'react';

const controlledform = () => {
  const [formdata, setformdata] = usestate({
    name: '',
    email: ''
  });

  const handlechange = (event) => {
    const { name, value } = event.target;
    setformdata((prevdata) => ({
      ...prevdata,
      [name]: value
    }));
  };

  const handlesubmit = (event) => {
    event.preventdefault();
    alert(`name: ${formdata.name}, email: ${formdata.email}`);
  };

  return (
    


); }; export default controlledform;

在此示例中,usestate 用于管理表单数据,每当用户在输入字段中键入内容时,handlechange 函数就会更新状态。

不受控制的组件

不受控制的组件是表单数据由 dom 本身处理的组件。您可以使用 refs 直接从 dom 元素访问表单数据。

使用 refs 访问表单数据

要创建不受控制的组件,您可以使用 useref 钩子为表单元素创建引用。

示例:

import react, { useref } from 'react';

const uncontrolledform = () => {
  const nameref = useref(null);
  const emailref = useref(null);

  const handlesubmit = (event) => {
    event.preventdefault();
    alert(`name: ${nameref.current.value}, email: ${emailref.current.value}`);
  };

  return (
    


); }; export default uncontrolledform;

在此示例中,nameref 和 emailref 引用用于在提交表单时直接从 dom 元素访问输入值。

表单验证

表单验证对于确保用户输入在提交之前满足所需的标准至关重要。

基本验证技术

您可以通过检查表单提交处理程序中的输入值来添加基本验证。

示例:

import react, { usestate } from 'react';

const basicvalidationform = () => {
  const [formdata, setformdata] = usestate({
    name: '',
    email: ''
  });
  const [errors, seterrors] = usestate({});

  const handlechange = (event) => {
    const { name, value } = event.target;
    setformdata((prevdata) => ({
      ...prevdata,
      [name]: value
    }));
  };

  const validate = () => {
    const newerrors = {};
    if (!formdata.name) newerrors.name = 'name is required';
    if (!formdata.email) newerrors.email = 'email is required';
    return newerrors;
  };

  const handlesubmit = (event) => {
    event.preventdefault();
    const newerrors = validate();
    if (object.keys(newerrors).length > 0) {
      seterrors(newerrors);
    } else {
      alert(`name: ${formdata.name}, email: ${formdata.email}`);
    }
  };

  return (
    


); }; export default basicvalidationform;

在此示例中,验证函数检查名称和电子邮件字段是否为空并相应地设置错误消息。

2088shop商城购物系统
2088shop商城购物系统

2088shop商城购物系统是商城系统中功能最全的一个版本:非会员购物、商品无限级分类、不限商品数量、商品多级会员定价、上货库存、Word在线编辑器、订单详情销售报表、商品评论、留言簿、管理员多级别、VIP积分、会员注册积分奖励、智能新闻发布、滚动公告、投票调查、背景图片颜色更换、店标上传、版权联系方式修改、背景音乐(好歌不断)、广告图片支持Flash、弹出浮动广告、搜索引擎关健词优化、图文友情联

下载

用于表单验证的第三方库

使用 formik 和 yup 等第三方库可以简化表单验证。

以福米克和是的为例:

import react from 'react';
import { formik, field, form, errormessage } from 'formik';
import * as yup from 'yup';

const signupschema = yup.object().shape({
  name: yup.string().required('name is required'),
  email: yup.string().email('invalid email').required('email is required'),
});

const formikform = () => (
  

signup form

{ alert(json.stringify(values, null, 2)); }} > {({ errors, touched }) => (


)}
); export default formikform;

在此示例中,formik 和 yup 用于处理表单状态和验证。 formik 提供了一种灵活且简单的方式来管理表单,而 yup 则帮助定义验证模式。

复杂表单管理

管理多步骤表单

管理多步骤表单涉及处理表单状态和步骤之间的导航。

示例:

import react, { usestate } from 'react';

const multistepform = () => {
  const [step, setstep] = usestate(1);
  const [formdata, setformdata] = usestate({
    name: '',
    email: '',
    address: '',
  });

  const nextstep = () => setstep(step + 1);
  const prevstep = () => setstep(step - 1);

  const handlechange = (e) => {
    const { name, value } = e.target;
    setformdata((prevdata) => ({
      ...prevdata,
      [name]: value
    }));
  };

  const handlesubmit = (e) => {
    e.preventdefault();
    alert(json.stringify(formdata, null, 2));
  };

  switch (step) {
    case 1:
      return (
        

step 1

); case 2: return (

step 2

); case 3: return (

step 3

); default: return null; } }; export default multistepform;

在此示例中,表单状态是跨多个步骤进行管理的。 nextstep 和 prevstep 函数处理步骤之间的导航。

处理表单中的文件上传

处理文件上传涉及使用文件输入元素和

在组件状态下管理上传的文件。

示例:

import React, { useState } from 'react';

const FileUploadForm = () => {
  const [file, setFile] = useState(null);

  const handleFileChange = (e) => {
    setFile(e.target.files[0]);
  };

  const handleSubmit = (e) => {
    e.preventDefault();
    if (file) {
      alert(`File name: ${file.name}`);
    } else {
      alert('No file selected');
    }
  };

  return (
    

); }; export default FileUploadForm;

在此示例中,handlefilechange 函数用所选文件更新状态,handlesubmit 函数处理表单提交。

结论

在 react 中管理表单涉及了解受控和非受控组件、实现表单验证以及处理复杂表单。通过掌握这些概念,您可以在 react 应用程序中创建健壮且用户友好的表单。作为一名初级开发人员,在这些领域打下坚实的基础将为您作为 react 开发人员继续学习和成长奠定成功的基础。

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

2929

2024.08.14

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

0

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

22

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

18

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

2

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

40

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号