当前位置:首页 > React

react 实现表单

2026-01-26 11:33:20React

React 表单实现方法

受控组件方式 通过React的state管理表单数据,每个表单元素绑定value和onChange事件。表单数据完全由React组件控制,适用于需要实时验证或复杂交互的场景。

import { useState } from 'react';

function ControlledForm() {
  const [formData, setFormData] = useState({
    username: '',
    password: ''
  });

  const handleChange = (e) => {
    const { name, value } = e.target;
    setFormData(prev => ({
      ...prev,
      [name]: value
    }));
  };

  const handleSubmit = (e) => {
    e.preventDefault();
    console.log(formData);
  };

  return (
    <form onSubmit={handleSubmit}>
      <input
        type="text"
        name="username"
        value={formData.username}
        onChange={handleChange}
      />
      <input
        type="password"
        name="password"
        value={formData.password}
        onChange={handleChange}
      />
      <button type="submit">Submit</button>
    </form>
  );
}

非受控组件方式 使用ref直接访问DOM元素获取表单值,适合简单表单或需要集成非React代码的情况。

react 实现表单

import { useRef } from 'react';

function UncontrolledForm() {
  const usernameRef = useRef();
  const passwordRef = useRef();

  const handleSubmit = (e) => {
    e.preventDefault();
    console.log({
      username: usernameRef.current.value,
      password: passwordRef.current.value
    });
  };

  return (
    <form onSubmit={handleSubmit}>
      <input type="text" ref={usernameRef} />
      <input type="password" ref={passwordRef} />
      <button type="submit">Submit</button>
    </form>
  );
}

使用表单库 对于复杂表单场景,推荐使用Formik或React Hook Form等专业表单库。这些库提供验证、错误处理等开箱即用的功能。

React Hook Form示例:

react 实现表单

import { useForm } from 'react-hook-form';

function FormWithLibrary() {
  const { register, handleSubmit, formState: { errors } } = useForm();

  const onSubmit = data => console.log(data);

  return (
    <form onSubmit={handleSubmit(onSubmit)}>
      <input {...register('username', { required: true })} />
      {errors.username && <span>This field is required</span>}

      <input 
        type="password" 
        {...register('password', { 
          required: true,
          minLength: 6 
        })} 
      />
      {errors.password && <span>Password must be 6+ characters</span>}

      <button type="submit">Submit</button>
    </form>
  );
}

表单验证实现 在受控组件中手动添加验证逻辑,或在表单库中使用内置验证规则。实时验证可提升用户体验。

const [errors, setErrors] = useState({});

const validate = () => {
  const newErrors = {};
  if (!formData.username) newErrors.username = 'Required';
  if (formData.password.length < 6) newErrors.password = 'Too short';
  setErrors(newErrors);
  return Object.keys(newErrors).length === 0;
};

const handleSubmit = (e) => {
  e.preventDefault();
  if (validate()) {
    console.log(formData);
  }
};

动态表单字段 使用数组state管理动态生成的表单字段,适用于需要添加/删除字段的场景。

const [fields, setFields] = useState([{ value: '' }]);

const addField = () => {
  setFields([...fields, { value: '' }]);
};

const removeField = (index) => {
  const newFields = [...fields];
  newFields.splice(index, 1);
  setFields(newFields);
};

标签: 表单react
分享给朋友:

相关文章

react中monent如何获取日期

react中monent如何获取日期

使用 Moment.js 获取日期 在 React 项目中,可以通过 Moment.js 库轻松处理日期和时间。以下是几种常见的日期获取方法。 安装 Moment.js 确保项目中已安装 Momen…

react如何保养

react如何保养

保持组件简洁 将大型组件拆分为更小、更专注的组件,每个组件只负责单一功能。避免在单个组件中处理过多逻辑或状态,这有助于提高可维护性和可测试性。 合理使用状态管理 根据应用复杂度选择状态管理方案。简单…

vue 实现表单

vue 实现表单

Vue 表单实现方法 Vue.js 提供了多种方式实现表单,包括双向数据绑定、表单验证和动态表单生成。以下是常见的实现方法: 基础表单绑定 使用 v-model 指令实现表单元素与数据的双向绑定:…

vue实现新增表单

vue实现新增表单

Vue 实现新增表单的方法 表单数据绑定 使用 v-model 指令实现表单数据的双向绑定。在 Vue 组件的 data 中定义表单数据的初始值。 data() { return { f…

css 制作表单

css 制作表单

使用 CSS 制作表单 表单是网页交互的重要组成部分,通过 CSS 可以美化表单元素,提升用户体验。以下是常见的表单样式设计方法。 基础表单结构 HTML 表单通常包含输入框、标签、按钮等元素。以下…

react native 如何

react native 如何

React Native 开发基础 React Native 是一个用于构建跨平台移动应用的框架,允许开发者使用 JavaScript 和 React 编写代码,同时生成原生 iOS 和 Androi…