gpt4 book ai didi

reactjs - 在 Formik 中使用 setFieldValue onSubmit

转载 作者:行者123 更新时间:2023-12-03 23:51:24 34 4
gpt4 key购买 nike

我正在使用 formik@jbuschke/formik-antdreact-input-mask .我有口罩 +7 (___) ___-__-__应用于其中一个输入,我需要解析它 onSubmit删除不必要的符号。

我定义了一个常量 changedValue ,然后在 setFieldValue 中使用,但我收到以下错误:

Invariant Violation
Maximum update depth exceeded. This can happen when a component repeatedly calls setState inside componentWillUpdate or componentDidUpdate. React limits the number of nested updates to prevent infinite loops.

这是我的代码和 demo :
const CloseForm = () => (
<Formik
initialValues={{ phone: "", email: "" }}
onSubmit={(values, { setSubmitting, setFieldValue }) => {
const changedValue = values.phone.replace(/\(|\)|\s|-/g, "");
setTimeout(() => {
setFieldValue("phone", changedValue);
alert(JSON.stringify(values, null, 2));
setSubmitting(false);
}, 400);
}}
validate={validatePhone}
>
{({ isSubmitting, values, handleChange }) => {
return (
<Form>
<FormItem name="phone" label="Phone" required="true">
<CustomInput
mask="+7 (999) 999-99-99"
name="phone"
onChange={handleChange}
/>
</FormItem>
<FormItem name="email" label="Email">
<Input name="email" />
</FormItem>
<SubmitButton type="primary" disabled={isSubmitting}>
Submit
</SubmitButton>
<pre>{JSON.stringify(values, null, 2)}</pre>
</Form>
);
}}
</Formik>
);

我该如何解决这个问题?或者可能有更好的方法来使用 setFieldValue解析值?

最佳答案

您可以在不更改字段的情况下修改要提交的值,例如:

onSubmit={values => {
const phone = values.phone.replace(/\(|\)|\s|-/g, "")
const valuesToSend = { ...values, phone }

alert(JSON.stringify(valuesToSend, null, 2))
}}

关于reactjs - 在 Formik 中使用 setFieldValue onSubmit,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57208048/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com