表单提交是一种结构化的操作,可以通过封装一些通用的功能达到简化开发的目的。本文将讨论Form表单组件设计的思路,并结合有赞的ZentForm组件介绍具体的实现方式。...二、Form组件功能 一般来说,Form组件的功能包括以下几点: 表单布局 表单字段封装 表单验证&错误提示 表单提交 下面将对每个部分的实现方式做详细介绍。...字段与表单之间的交互是一个需要考虑的问题,表单需要知道它包含的字段值,需要在适当的时机对字段进行校验。ZentForm的实现方式是在Form的高阶组件内维护一个字段数组,数组内容是Field的实例。...太多的情况下对整个表单字段进行了校验,比较合理的情况应该是某个字段修改的时候只校验本身,在表单提交时再校验所有的字段。 表单提交操作略显繁琐,还需要调用一次handleSubmit,不够优雅。...希望阅读完本文后,你对React的Form组件实现有更多的了解,也欢迎留言讨论。
2 受控和非受控表单差异 2.1 受控表单的特点和使用场景 受控表单是指表单元素的值受 React 组件的 state 或 props 控制。...特点: 表单元素的值保存在组件的 state 中,以便在需要时进行访问、验证或提交。每当用户输入发生变化时,需要手动更新 state 来反映新的值。...表单的整体控制 对表单数据有更好的控制 对表单数据的控制有限 数据流 可以根据表单元素的值动态地改变其他组件的状态或行为 需要通过 ref 来获取表单元素的值,不符合 React 的数据流思想。...不同于 rc-field-form 中使用的受控表单来做表单状态管理,react-hook-form 使用了 React 的 useRef 和 useReducer 来处理表单数据的状态,而不是使用...以非受控表单形式实现的 react-hook-form 采用订阅模式来实现不同场景
ref,需要手动进行传递,具体请看传递refs 状态管理 将原组件的状态提取到 HOC中进行管理,如下面的代码,我们将 Input的 value提取到 HOC中进行管理,使它变成受控组件,同时不影响它使用...而 React中没有做这样的处理,在默认情况下,表单元素都是 非受控组件。...首先我们自定义一个 Form组件,该组件用于包裹所有需要包裹的表单组件,通过 contex向子组件暴露两个属性: model:当前 Form管控的所有数据,由表单 name和 value组成,如 {name...的注意事项 使用范围 只能在 React函数式组件或自定义 Hook中使用 Hook。...Hook的提出主要就是为了解决 class组件的一系列问题,所以我们能在 class组件中使用它。 声明约束 不要在循环,条件或嵌套函数中调用Hook。
loader 返回值React 组件可以嵌套,也可以嵌套,这时可以通过该 hook 获取其它 的 loader 的返回值。...action 是用户提交 form 时,做 POST PUT DELETE 等操作时,执行的。...以前写过的都知道,它有 action 和 method 参数,在以前,提交表单也是在浏览器内做了一次改变URL的操作。...使用React后,几乎没人这么做,大家都是AJAX或Fetch提交表单了。...现在,React Router 提供了 组件,并给 组件增加了 action 属性,让提交表单也变成一次路由。实在是忍不住了,想发表个人观点:感觉没用,屁用没有。
当用户提交表单时,来自上述元素的值将随表单一起发送。 而 React 的工作方式则不同。...包含表单的组件将跟踪其状态中的输入值,并在每次回调函数(例如onChange)触发时重新渲染组件,因为状态被更新。以这种方式由 React 控制其值的输入表单元素称为受控组件。...主题: React 难度: ⭐⭐⭐ 首先,Hooks 通常支持提取和重用跨多个组件通用的有状态逻辑,而无需承担高阶组件或渲染 props 的负担。...主题: React 难度: ⭐⭐⭐ 在构建 React 应用程序时,在多层嵌套组件来使用另一个嵌套组件提供的数据。...通过定义提供数据的Provider组件,并允许嵌套的组件通过Consumer组件或useContext Hook 使用上下文数据。 问题 23:描述 Flux 与 MVC?
React中实现了组件的状态管理,组件的渲染,组件的嵌套等等一系列围绕组件所实现的特性,而在16.8.x以前,这些特性主要是围绕着Class组件来实现的,既然react有了这样的能力,何不将其也赋予在Function...HOC和renderProps显然不是理想的方案。 你可以使用 Hook 从组件中提取状态逻辑,使得这些逻辑可以单独测试并复用。... ); } } 现在有了另外一种解决方案,使用hook将获取表单项的值,监听值的改变,再赋值的逻辑封装起来...> ); } 我们可以通过formState获取到最新表单的值,调用text或者password就会返回对应的表单控件属性,value、onChange包括一些type、name字段也一并返回...,只要其中一个hook触发了更新函数,都会按照链表的顺序执行更新,这就对应上了官方的对于使用hooks的建议:不要在循环,条件或嵌套函数中调用 Hook,很明显,如果在条件语句中使用了hook会导致hook
使用“States”存在问题 正如我们已经知道的那样,每当组件内的状态变量的值发生变化时,React都会重新渲染组件以匹配其当前状态。...# pnpm pnpm create vite my-vue-app --template react 让我们创建一个 React 组件(称为 FormWithState ),其中包含一个表单,该表单接受两个输入...在大多数情况下,表单值仅在表单提交时使用。那么,难道为了两个输入字段就需要重新渲染20多次的组件吗?答案是明确的:不需要!...然后,我们通过 FormData.entries() 方法迭代获取表单的键和值来构建表单主体。我们可以使用这个对象进行进一步的输入验证和通过 fetch 或 Axios API进行提交。...使用FormData的优势 表单输入值会自动捕获,无需为每个输入字段维护状态变量。 使用 FormData 时,API请求体可以很容易地构建,而使用 useState 时,我们需要组装提交的数据。
,而且运行效果完全相同没有啥不同,具体的差异如下: 整个类构造函数已被 useState Hook 替换,它只包含一行。...由于 useState Hook 输出局部变量,因此您不再需要使用 this 关键字来引用您的函数或状态变量。...如上图所示,我们创建三个组件:表单组件 IngredientForm ,商品清单列表组件 IngredientList ,清单页面组件 Ingredients(将表单组件和商品清单列表组件包含在内),还有一个...,我们就可以在其中嵌套我们的表单组件了。...基于需求,这里我们有两个表单输入框和提交按钮,分别用于录入商品名称、单价和提交数据。
传递给action props的函数默认使用Action机制,并在提交后自动重置表单 Action将允许我们将action与标签 集成。...在我们的 JSX 中,我们可以删除 的 onSubmit 事件,并使用 action 属性。action 属性的值将是一个「提交数据的方法」,可以在客户端或服务器端提交数据。...data:一个实现了 FormData 接口的对象,其中包含父 提交的数据。 method:HTTP 方法 – GET,或 POST。 默认情况下将是 GET。...当我们想要知道表单提交的状态并相应地显示数据时,它会很有用。 useFormState() hook React19 中的另一个新 hook 是 useFormState。...); fn:表单提交或按钮按下时要调用的函数。 initialState:我们希望状态初始值是什么。它可以是任何可序列化的值。在首次调用操作后,此参数将被忽略。 permalink:这是可选的。
React 19 提供了名为 useFormStatus 的 hook 来帮助我们做到这个事情。...2、useFormStatus 和别的 hook 不同的是,我们需要从 react-dom 中获取到它的引用 import { useFormStatus } from "react-dom"; useFormStatus...能够在 form 元素的子组件中,获取到表单提交时的 pending 状态和表单内容。...实现非常简单,我们将某一个字段单独封装到子组件中,利用 useFormStatus 提供的 pending 状态来判断是否禁用输入,代码如下 function Input2({required, name...> 5、总结 useFormStatus 是结合 action 异步请求时使用的 hook,它们是对 HTML 表单能力的增强。
路由 react-router React Router 不仅仅是将 URL 与函数或组件匹配:它还涉及构建一个完整的用户界面,该界面与 URL 相对应,因此可能比你习惯的更多概念。...字段,并在组件挂载和卸载时管理缓存数据的生命周期 RTK Query 提供了“缓存条目生命周期”选项,可以通过 WebSocket 消息流式传输缓存更新,以在获取初始数据后使用 我们有从 OpenAPI...由于大约有 30 个独特的表单,很快就明显发现,我们可以通过标准化不仅是输入组件,还有数据在表单中的流动方式来获益。 为什么不使用 Redux-Form?...> )} ); export default Basic; React Hook Form 作者自述:我对 React 最大的抱怨就是表单。...对于 Counter 组件,它的状态逻辑大致如下: 我们把这些状态逻辑收敛到一个叫 useCounter 的 React Hook 中。
可组合的表单字段:Formik 支持自定义表单字段组件,使你能够灵活地创建复杂的表单布局。...与其他库集成:Formik 可以与其他流行的库和工具(如 Yup、React Hook Form)集成,提供更多的扩展性和灵活性。...其核心组件包括: Formik 组件:管理表单状态和逻辑的核心组件,它接受表单的初始值、验证函数和提交函数,并提供了一系列工具方法来处理表单的状态和逻辑。...Field 组件:用于渲染表单字段的组件,它接受表单字段的名称、类型和验证规则等参数,并根据这些参数渲染相应的表单字段。...Form 组件:用于包裹表单字段和提交按钮的组件,它接受表单的提交函数等参数,并提供了一个提交按钮来提交表单数据。
在 HTML 中,表单元素如 、和通常维护自己的状态,并根据用户输入进行更新。当用户提交表单时,来自上述元素的值将随表单一起发送。...而 React 的工作方式则不同。包含表单的组件将跟踪其状态中的输入值,并在每次回调函数(例如onChange)触发时重新渲染组件,因为状态被更新。...以这种方式由 React 控制其值的输入表单元素称为受控组件。...首先,Hooks 通常支持提取和重用跨多个组件通用的有状态逻辑,而无需承担高阶组件或渲染 props 的负担。Hooks 可以轻松地操作函数组件的状态,而不需要将它们转换为类组件。...但在大部分场景下,Hook 足够了,并且能够帮助减少嵌套。(1)HOC 官方解释∶高阶组件(HOC)是 React 中用于复用组件逻辑的一种高级技巧。
React围绕form新出了如下2个hook: useOptimistic useFormStatus 本文会聊聊React围绕form的布局与发展。...从用户体验的角度看,如果前端禁用了JS,那么React不能运行,上述交互失效。如果在禁用JS的情况下也能提交表单就好了。...目标1 HTML原生的form元素有个action属性,可以接收一个url。当提交表单(比如点击type为submit的按钮)后formData会提交给该url。...2个新hook 为了更好的服务server action,React团队新出了2个hook用于提高form场景下的用户体验: useOptimistic useFormStatus 当前,这2个hook...当某个form触发表单提交时,context的值会被更新为这个form的数据。useFormStatus本身仅仅是useContext(上述context)。
本文知识要点 Hook 高阶组件 组件通信 上下文 React.cloneElement Hook 文档地址:https://zh-hans.reactjs.org/docs/hooks-intro.html...不过对于傻瓜组件,可以不考虑接耦。也不见得这种方法完全取代redux。 React表单组件设计 除了重构,还有一个重要的地方是造轮子。 antd的表单实现 ?...开发表单组件,至少考虑三个问题: 数据收集 校验 提交 表单的结构如下 | - Form |-FormItem |-校验规则渲染下的表单组件 校验是怎么实现的?...const { getFieldDecorator } = this.props.form; 代码里没有提及 this.props.form是如何创建的,这其实是一个高阶组件,参数包括字段名/校验规则/...设计思想:假设有一个组件,只管样式。通过高阶组件的处理,就成了一个完整功能的表单。 如何收集数据?
container); 一种将子节点渲染到 DOM 节点中的方式 Hook:React 16.8 的新增特性。...它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。 规则1:不要在循环,条件或嵌套函数中调用 Hook, 确保总是在你的 React 函数的最顶层调用他们。...useImperativeHandle useImperativeHandle 可以让你在使用 ref 时自定义暴露给父组件的实例值。使用场景如Antd4 Form实现Form的时候。...创建视图以响应状态的变化 • observer HOC • 返回响应式组件,它可以自动追踪哪个可观察量被使用了以及当值改变的时候自动重新渲染这个组件。...• Observer component • 只能使得它自己的返回组件是响应式的,如果你里面还嵌套了别的组件,那这个里面的组件得靠自己变成响应式~ • useObserver hook • 优点:
client';import { useForm } from 'react-hook-form';import { toast } from 'react-hot-toast'; // updated...> );}在这里,您执行了以下操作:从库导入的useForm钩子react-hook-form来处理表单状态和提交。...toast从库导入react-hot-toast,在成功发送电子邮件后显示通知。定义一个名为 的异步函数onSubmit来在用户提交表单时处理表单提交。...reset提供的功能用于useForm在提交后重置表单字段。实施动态电子邮件模板使用 React Email,创建现代电子邮件模板变得非常容易。...该POST函数是一个异步函数,用于处理传入的 POST 请求。、和变量是从解析的请求正文中提取的name。emailmessage现在,导航到项目的主页并在表单字段中输入一些数据。点击“预约”按钮。
使用 useReducer hook useReducer 是 useState 的替代品,它可以更好的管理组件的状态。...Formik 工具库 Formik 库可以让你在 React 中轻松构建出健壮的 Form 表单程序。...它有一个 as 属性,值可以是 React 组件,也可以是要呈现的 HTML 元素的名称。... 用于构建表单的组件。用于集中处理表单逻辑。.../> 组件可以让你不用再手动创建 onSubmit 或 onResize 事件句柄,在 Formik 组件中直接书写即可。
众所周知,hook 在 React 组件开发中变得越来越重要,特别是在功能组件中,因为它们已经完全取代了对基于类的组件的需求,而基于类的组件是管理有状态组件的传统方式。...useState hook 可能很难理解,特别是对于新手 React 开发人员或从基于类的组件迁移到函数组件的开发人员。...例如,我们有一个组件,它期望一个包含用户名称、图像和个人简历的用户对象状态——在这个组件中,我们呈现用户的属性。...管理表单中的多个输入字段 管理表单中的几个受控输入通常是通过为每个输入字段手动创建多个 useState() 函数并将每个函数绑定到相应的输入字段来完成的。...这可能是相当多余和耗时的,因为它涉及编写大量代码,降低了代码库的可读性。 但是,只使用一个 useState hook 就可以管理表单中的多个输入字段。
适用场景: 表单和表单域: 当设计表单时,可以使用复合式组件将整个表单拆分成多个表单域组件,每个表单域负责处理特定的输入或验证逻辑。这样可以更好地组织表单逻辑,提高可维护性。...对话框和模态框: 对话框或模态框通常包含标题、内容和操作按钮。可以使用复合式组件将这些部分拆分成独立的组件,以便在应用中以不同方式重复使用。 2....不适用于所有场景:受控组件更适用于表单交互比较复杂,需要实时验证或涉及多个输入字段之间关系的场景。对于简单的表单,可能显得有些繁重。...适用场景: 数据获取和处理逻辑: 将数据获取和处理逻辑提取到自定义 Hook 中,可以在多个组件之间共享相同的数据逻辑。...副作用的封装: 当有需要在组件中处理副作用的情况,可以将副作用逻辑封装到自定义 Hook 中,以提高可维护性。 4.
领取专属 10元无门槛券
手把手带您无忧上云