表单是 Web 应用程序不可或缺的一部分,支持用户交互和数据收集。在 React.js 中,构建表单涉及使用状态管理和组件驱动架构来确保效率和可维护性。本指南将涵盖在 React.js 中构建表单的最佳实践,使您的应用程序健壮且用户友好。
受控组件是 React 中处理表单输入的首选方式。它们将表单数据保留在组件状态中,从而更易于管理和验证。
将所有表单输入值存储在一个状态中。创建一个对象并将所有输入与其状态中的属性映射,示例如下
import React, { useState } from 'react'; const MyForm = () => { const [formData, setFormData] = useState({ name: '', email: '' }); const handleChange = (e) => { const { name, value } = e.target; setFormData({ ...formData, [name]: value }); }; const handleSubmit = (e) => { e.preventDefault(); console.log(formData); }; return ()} export default MyForm
错误处理和验证是表单的重要组成部分。您必须验证并检查用户输入的每个值是否有错误,并处理所有情况,例如:
必须实现客户端验证以增强用户体验并减少服务器负载,从而最终提高性能。利用 Yup 等库或自定义验证逻辑来确保数据完整性。
让我们看看,如何实现自定义验证逻辑
const validate = (formData) => { const errors = {}; if (!formData.name) errors.name = 'Name is required'; if (!formData.email) errors.email = 'Email is required'; return errors; }; const MyForm = () => { const [formData, setFormData] = useState({ name: '', email: '' }); const [errors, setErrors] = useState({}); const handleSubmit = (e) => { e.preventDefault(); const validationErrors = validate(formData); if (Object.keys(validationErrors).length === 0) { console.log(formData); } else { setErrors(validationErrors); } }; return (); };
为了工作方便,必须使用Yup包来顺利验证表单数据。它是一个非常流行的包,与 React-Hook-Form 或 Formik 等表单库一起使用。
是的文档:https://www.npmjs.com/package/yup
Formik 和 React Hook Form 等库简化了表单管理,提供了开箱即用的强大功能,并使开发人员可以轻松地以更具可扩展性和灵活的方式构建和验证表单
使用 Formik:
文档:- https://formik.org/docs/overview
import React from 'react'; import ReactDOM from 'react-dom'; import { Formik, Field, Form } from 'formik'; const BasicForm = () => (); ReactDOM.render(Sign Up
{ await new Promise((r) => setTimeout(r, 500)); alert(JSON.stringify(values, null, 2)); }} > , document.getElementById('root'));
点击查看现场Formik演示
通过遵循这些最佳实践,在 React.js 中构建表单可以变得简单而高效。使用受控组件进行状态管理,彻底验证输入,利用第三方库,通过适当的样式增强用户体验,并优化性能以创建响应灵敏且健壮的表单。
通过遵守这些准则,您可以确保您的表单可靠、用户友好且可维护,为用户和开发人员提供无缝体验。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3