gpt4 book ai didi

reactjs - 为什么没有填充 Formik `touched` 属性?

转载 作者:行者123 更新时间:2023-12-03 17:43:49 27 4
gpt4 key购买 nike

我正在使用 React、Formik、react-bootstrap 和 yup 制作表单以进行验证。我试图显示验证错误,但 touched属性未填充字段。

const schema = yup.object({
name: yup.string().required(),
email: yup
.string()
.email()
.required(),
});

const ChildForm = props => {
const { child: { name = '', email = '' } = {} } = props;
const submitHandler = ({name, email}) => console.log(name, email);

return (
<Formik
validationSchema={schema}
onSubmit={submitHandler}
initialValues={{ name, email }}
render={({ handleSubmit, handleChange, values, touched, errors }) =>
{
console.log('touched: ', touched);
return (
<Form noValidate className="mt-4" onSubmit={handleSubmit}>
<Form.Row>
<Form.Group as={Col} controlId="name">
<Form.Label>Full Name</Form.Label>
<Form.Control
name="name"
required
value={values.name}
onChange={handleChange}
isValid={touched.name && !errors.name}
isInvalid={touched.name && errors.name}
type="text"
placeholder="Your child's name"
/>
<Form.Control.Feedback>Looks good!</Form.Control.Feedback>
<Form.Control.Feedback type="invalid">
{errors.name || 'Please enter your child\'s name'}
</Form.Control.Feedback>
</Form.Group>
</Form.Row>
<Form.Row>
<Form.Group as={Col} controlId="email">
<Form.Label>Email Address</Form.Label>
<Form.Control
name="email"
required
value={values.email}
onChange={handleChange}
isValid={touched.email && !errors.email}
isInvalid={touched.email && errors.email}
type="text"
placeholder="Your child's email address"
/>
<Form.Control.Feedback>
No spam, we promise!
</Form.Control.Feedback>
<Form.Control.Feedback type="invalid">
{errors.email || 'Please enter a valid email address'}
</Form.Control.Feedback>
</Form.Group>
</Form.Row>
<Form.Row className="float-right">
<Button variant="success" onClick={handleSubmit}>
<Icon icon={faSave} />
&nbsp; Submit
</Button>
</Form.Row>
</Form>
);
}}
/>
);
}

我在这里做错了什么? console.log(touched)总是显示一个空对象。

最佳答案

@djheru 您的解决方案是正确的,因为 Formik 设置了 touched blur 上的标志事件而不是在 change . Here是 Formik 作者对此的评论:
您必须调用 Formiks handleBlur通知 Formik blur事件已被触发 - 所以是的,这些处理程序是需要的。

关于reactjs - 为什么没有填充 Formik `touched` 属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57385931/

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