react-hook-form 中的 react-table v7

IT技术 reactjs react-table react-hook-form react-forms
2021-05-18 01:12:47

我正在研究一种复杂的react形式,其中几乎没有受控输入以及网格/表格。目前我正在使用 react-hook-form 进行验证。
这是我的模型。这里的想法是根据需要显示网格,直到用户添加一些数据。用户可以通过单击“+”或“-”按钮来添加/删除数据。 当我在这里提交是我在提交的数据中看到的

小样

{
  "fname": "sasa",
  "lname": "asasasa"
} 

这是预期的输出

{
  "fname": "sasa",
  "lname": "asasasa",
  "localAddress":[
    {
      "street1":"street1",
      "street2":"street2",
      "city":"city"
    },
    {
      "street1":"street2",
      "street2":"street2",
      "city":"city"
    }
  ]
} 



这是我的 codesanbox
Codesanbox

不知道如何将 react-table(或任何 table 组件)与 react-hook-form(或任何 react 形式)集成。使用“react-table”构建表单对我来说是必须的。

感谢任何帮助。

2个回答

正如“使用 UI 库”部分的入门文档中所述:

选项 3:我们可以使用useEffect Hook设置自定义寄存器并通过setValue.

所以这里是你的情况需要做的事情:

export default function App() {
  const { register, handleSubmit, setValue } = useForm();
  // ... 

  React.useEffect(() => {
    register({ name: "localaddress" });
  }, [register]);

  const addLocalAddress = function() {
    // ... 
    setValue("localaddress", d);
    setLocalAddress(d);
  };

  // ... 
}

有了这个,你需要Controller通过替换这个来摆脱

<Controller
  name="tag"
  control={methods.control}
  as={
    <Table1
      name="tag"
      ref={methods.register}
      columns={columns}
      data={localAddress}
      {...methods}
    />
  }
/>;

有了这个:

<Table1 columns={columns} data={localAddress} />

应该是这样。当然还有沙箱

干得好 :

第一:我们需要input盒子,name它可以生成文本输出

name="localAddress[0][street1]"
name="localAddress[0][street2]"
name="localAddress[0][city]"

name="localAddress[1][street1]"
name="localAddress[1][street2]"
name="localAddress[1][city]"


// to generate the name you can do something like this
<Input
    type="text"
    name={`localAddress[${i}][${columns[j]["accessor"]}]`}
    placeholder={columns[j]["accessor"]}
    innerRef={methods.register}
/>

第二: 我们需要访问methods

// pass it from props
<Table1
    name="tag"
    ref={methods.register}
    columns={columns}
    data={localAddress}
    methods = {methods} // <---- Pass HERE
/>

// access it via props
export const Table1 = React.forwardRef(({ columns, data, methods }, ref) => { 

工作演示:(对于输出,您可以检查控制台)

编辑#SO-hook-forms-solved