首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >提交后刷新react-hook-form字段

提交后刷新react-hook-form字段
EN

Stack Overflow用户
提问于 2020-11-11 16:07:07
回答 1查看 2.3K关注 0票数 1

我将react-hook-form字段作为子级发送到另一个函数组件。按下提交按钮后,该字段将刷新,输入的值将被删除。有什么问题吗?

CodeSandBox example is here

我的文件App.js

代码语言:javascript
复制
import React from "react";
import "./styles.css";
import { useForm } from "react-hook-form";
import { Box, Button, Grid, TextField } from "@material-ui/core";

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

  function onSubmit(data) {
    console.log(data);
  }

  function FieldComponent(props) {
    const { title, children } = props;
    return (
      <Grid container alignItems="center">
        <Grid item xs={3}>
          <Box py={5}>
            <div fontWeight="bold" fontSize="16">
              {title}
            </div>
          </Box>
        </Grid>
        <Grid item xs={9}>
          <Box py={5}>{children}</Box>
        </Grid>
      </Grid>
    );
  }

  return (
    <div className="App">
      <Grid container>
        <Grid item xs={12}>
          <FieldComponent title="name">
            <TextField variant="outlined" name="name" inputRef={register} />
          </FieldComponent>
        </Grid>
        <Grid item xs={12}>
          <Button variant="outlined" onClick={handleSubmit(onSubmit)}>
            Submit
          </Button>
        </Grid>
      </Grid>
    </div>
  );
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-11 16:57:22

移动子组件到自己的组件中总是一个好主意,否则,每次重新渲染都会挂载和卸载您的组件。

代码语言:javascript
复制
function FieldComponent(props) {
  const { title, children } = props;
  return (
    <Grid container alignItems="center">
      <Grid item xs={3}>
        <Box py={5}>
          <div fontWeight="bold" fontSize="16">
            {title}
          </div>
        </Box>
      </Grid>
      <Grid item xs={9}>
        <Box py={5}>{children}</Box>
      </Grid>
    </Grid>
  );
}

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

  function onSubmit(data) {
    console.log(data);
  }

  return (
    <div className="App">
      <Grid container>
        <Grid item xs={12}>
          <FieldComponent title="name">
            <TextField variant="outlined" name="name" inputRef={register} />
          </FieldComponent>
        </Grid>
        <Grid item xs={12}>
          <Button variant="outlined" onClick={handleSubmit(onSubmit)}>
            Submit
          </Button>
        </Grid>
      </Grid>
    </div>
  );
}

https://codesandbox.io/s/agitated-darkness-leg7z?file=/src/App.js

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64782640

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档