javascript - React Hook Form - 智能组件 - 当输入被包装在元素中时表单被破坏

标签 javascript reactjs forms react-hook-form

按照教程进行操作 - https://www.react-hook-form.com/advanced-usage#SmartFormComponent ) - 一直工作,直到输入被包装在元素中。 需要对表单组件进行哪些更改才能实现此功能?

<Form onSubmit={(data) => setData(data)}>
    {/* wrapping the inputs breaks the form */}
    <div>
        <Input name="firstName" />
        <Input name="lastName" />
    </div>

    <button>Submit</button>
</Form>

解决这个问题的一个巧妙的方法是创建类似的东西:

const InputWithDiv = props => (
  <div>
    <Input {...props} />
  </div>
)

引用:https://stackoverflow.com/a/66215997/2102042

但这不是解决方案


👀👉示例:https://codesandbox.io/s/react-hook-form-smart-form-component-forked-8o0f9?file=/src/index.js

最佳答案

我认为你必须使用FormContext这里。还有这个discussion由建议使用 FormContext 的库的作者回答对于输入深度嵌套的场景。例如,当使用 <fieldset /> 时或片段或如您的情况 <div /> .

Edit React Hook Form - Smart Form Component (forked)

Here是文档中的相关部分。

关于javascript - React Hook Form - 智能组件 - 当输入被包装在元素中时表单被破坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68558867/

相关文章:

jQuery 验证和表单插件

python - Django 中的表单预览

javascript - 测试互联网(谷歌、AWS 等)是否可访问的最粗鲁的方法

javascript - 在家里我得到那个错误 : The action 'SET_PARAMS' with the payload {"params": {"company" :"Marciello Resto 2"}} was not handled by any navigator

wordpress - React/WordPress PWA 离线时不会响应 200

javascript - 状态改变不影响其他元素

java - GWT 捕获 HttpServlet 抛出的异常

javascript - 带有 D3v 3.5.13 图例和工具提示的简单 D3 折线图错误

javascript - 如何使用jquery更改图像的src路径

javascript - 为什么我的 SVG 形状之间存在间隙?