首页 > 解决方案 > 使用 Yup 的 react-hook-form 解析器类型错误

问题描述

我正在创建一个身份验证表单,并且我正在参考 react-hook-form文档,了解如何使用 yup 来验证我的输入。据我所知,一切都与文档中提供的实现几乎相同。但是,我在useForm解析器上遇到错误(如下所示)。知道我哪里出错了吗?

错误

在此处输入图像描述

代码

interface IFormInputs {
  email: string;
  password: string;
  passwordConfirm: string;
}

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

const SignUp = (): JSX.Element => {
  const {
    control,
    handleSubmit,
    getValues,
    formState: { errors },
  } = useForm<IFormInputs>({ resolver: yupResolver(schema) });

  const onSubmit: SubmitHandler<IFormInputs> = () => {
    const values = getValues();
    console.log('values', values);
  };

  return (
    <div>
      <StyledPaper>
        <StyledTypography>Sign Up</StyledTypography>
        <form onSubmit={handleSubmit(onSubmit)}>
          <Controller
            name="email"
            rules={{ required: 'this field is required' }}
            defaultValue=""
            control={control}
            render={({ field }) => (
              <TextField
                fullWidth
                label="Email"
                variant="filled"
                value={field.value}
                error={!!errors.email}
                helperText="Provide an email"
                {...field}
              />
            )}
          />
          <StyledButton type="submit">Submit</StyledButton>
        </form>
      </StyledPaper>
      <div>
        <StyledTypography>Already have an account? Log in.</StyledTypography>
      </div>
    </div>
  );
};

export default SignUp;

标签: reactjsreact-hook-form

解决方案


这看起来像一个库错误,将@hookform/resolvers降级到2.8.0似乎可以解决问题。

Codesandbox 演示

编辑:您可以2.8.1通过强制yubResolver使用yub.AnyObjectSchema泛型来消除版本上的错误。感谢 Mihai-github解决这个问题。

useForm<IFormInputs>({
  resolver: yupResolver<yup.AnyObjectSchema>(schema),
});

Codesandbox 演示


推荐阅读