使用 Yup 的 react-hook-form 解析器类型错误

react-hook-form resolver type error using Yup

我正在创建一个身份验证表单,我正在引用 react-hook-form docs 来了解如何使用 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;

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

编辑: 您可以通过强制 yubResolver 使用 yub.AnyObjectSchema 泛型来消除版本 2.8.1 上的错误。感谢 Mihai-github 搞清楚了。

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