首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React Formik :如何使用formik值进行useEffect?

React Formik :如何使用formik值进行useEffect?
EN

Stack Overflow用户
提问于 2020-11-25 18:21:42
回答 2查看 1.2K关注 0票数 2

如果formik的值发生了变化,我想使用useEffect来重新呈现一个字段。但是它不起作用..

实际上,我创建了一个小示例来说明我的问题。这里我有一个字段'title',如果这个字段发生了变化(当我们在里面写的时候),它应该调用useEffect并输出'update!‘但事实并非如此!

代码语言:javascript
复制
const FormikWidgetConfigurator = (props) => {
  useEffect(() => {
     // doesn't work if values has changed
     console.log('update!')
  }, [props.values]);

  return (
    <Form onSubmit={ props.handleSubmit } noValidate>
      <Form.Group className='py-3' >
        <Col md='6' style={{ padding: '0px' }}>
          <Form.Group controlId='title'>
            <Form.Control
              type='text'
              value={ props.values.title }
              onChange={props.handleChange}
            />
          </Form.Group>
        </Col>
      </Form.Group>
    </Form>
  )
}

const WidgetConfigurator = withFormik({
  mapPropsToValues(props) {
    return {
      title: 'No Title'
    };
  },

  validationSchema: props => Yup.object().shape({title: Yup.string()}),

  handleSubmit(values, { setSubmitting }) {// handle submit}
})(FormikWidgetConfigurator);

export default WidgetConfigurator;

编辑:实际上它是按照预期的方式工作的。(我没有改变任何东西)

谢谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-11-25 18:45:52

使用普通的Formik,您的方法是有效的。

我猜问题出在您的自定义组件、Form.ControlForm.Group

票数 2
EN

Stack Overflow用户

发布于 2021-09-30 15:55:35

这不是一个很好的解决方案,但我发现的一个技巧是在Formik表单中有一个不可见的按钮;它可以访问Formik的所有属性,并将在其onClick中执行所需的任何逻辑。然后,您可以通过document.getElementById("..").click()useEffect模拟单击该按钮的过程。

代码语言:javascript
复制
// Style it to be invisible
<Button id="testButton" type="button" onClick={() => {
    setFieldValue('test', '123');
    setTouched({});    
    // etc. any Formik action
}}>
</Button> 

useEffect:

代码语言:javascript
复制
useEffect(() => {
    document.getElementById("testButton").click(); // Simulate click
}, [dependency);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65002691

复制
相关文章

相似问题

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