
本文详细阐述了在使用 react-hook-form 时,如何正确处理表单提交以避免页面刷新、数据暴露在url以及验证失败的问题。核心在于理解 handlesubmit 的正确用法,即将其返回值直接赋给
这种写法是导致页面刷新的主要原因。当 React 渲染组件时,onSubmit={() => handleSubmit(onSubmit)} 这段代码会被执行。这意味着 handleSubmit(onSubmit) 会被立即调用,并将其返回值(一个事件处理函数)包装在一个新的匿名箭头函数 () => ... 中。
问题在于,当表单实际提交时,React 调用的并不是 handleSubmit 返回的那个能够阻止默认行为的函数,而是这个外部的匿名箭头函数。这个匿名箭头函数在执行时,仅仅是再次调用了 handleSubmit 返回的函数,但此时它并没有接收到原生的 SyntheticEvent 对象。由于没有 event 对象,handleSubmit 内部的 event.preventDefault() 也就无法被执行,导致浏览器执行了默认的表单提交行为,从而引发页面刷新。
正确姿势:直接传递 handleSubmit 的返回值
要正确地阻止页面刷新并确保 react-hook-form 的验证机制正常工作,应该将 handleSubmit 的返回值直接赋给
在这种写法中,handleSubmit(onSubmit) 会在组件渲染时被调用一次,它会返回一个已经“准备好”的事件处理函数。React 会将这个返回的函数作为










