在React中使用yup库进行表单验证的步骤如下:
npm install yup
import * as yup from 'yup';
const schema = yup.object().shape({
email: yup.string().email().required(),
password: yup.string().min(6).required(),
});
import React, { useState } from 'react';
import { useFormik } from 'formik';
const MyForm = () => {
const formik = useFormik({
initialValues: {
email: '',
password: '',
},
validationSchema: schema,
onSubmit: values => {
alert(JSON.stringify(values, null, 2));
},
});
return (
<form onSubmit={formik.handleSubmit}>
<input
type="text"
name="email"
onChange={formik.handleChange}
onBlur={formik.handleBlur}
value={formik.values.email}
/>
{formik.touched.email && formik.errors.email && <div>{formik.errors.email}</div>}
<input
type="password"
name="password"
onChange={formik.handleChange}
onBlur={formik.handleBlur}
value={formik.values.password}
/>
{formik.touched.password && formik.errors.password && <div>{formik.errors.password}</div>}
<button type="submit">Submit</button>
</form>
);
};
export default MyForm;
在上面的例子中,我们使用useFormik hook创建一个表单,并将yup的schema传递给validationSchema属性。在表单的input元素中,我们通过formik.handleChange和formik.handleBlur来处理用户输入和表单的blur事件,formik.errors.email和formik.errors.password会显示相应字段的错误信息。
通过上述步骤,就可以在React中使用yup库进行表单验证了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。