[英]react-hook-form v7 `watch` type in typescript?
我对如何将watch
的类型声明为道具感到困惑。 这是一个例子:
// pages/FormContainer.tsx
import { useForm, useWatch } from "react-hook-form";
import FormView from "./FormView";
interface FormInputs {
firstName: string;
lastName: string;
age: number;
}
const FormContainer = () => {
const { control, register } = useForm<FormInputs>({
defaultValues: {
firstName: "Jon",
lastName: "Doe",
age: 24
}
});
const formData = useWatch({ control });
return <FormView register={register} formData={formData} />;
};
export default FormContainer;
// pages/FormView.tsx
import { UseFormReturn } from "react-hook-form";
interface Props {
register: UseFormReturn["register"];
formData: UseFormReturn["watch"];
}
const FormView = ({ formData }: Props) => {
return (
<div>
<h1>
My Name: {formData.firstName} {formData.lastName}
</h1>
<h2>I am {formData.age} years old</h2>
</div>
);
};
export default FormView;
事情是 typescript 在这个formData={formData}
道具上显示一个错误
在这里,我提供了一个沙箱来明确我的意思
UseFormReturn["watch"]
将返回watch
function 本身的类型 - 即此 function 的类型:
// `watch` here is of type `UseFormReturn["watch"]
const { control, register, watch } = useForm<FormInputs>({
// ...
});
作为参考,此watch
function 的返回类型为UnpackNestedValues<TFormValues>
。
但是 - 你没有使用 function,你使用的是useWatch
,它返回一个略有不同的UnpackNestedValue<DeepPartialSkipArrayKey<TFieldValues>>
。 因此,您可以将表单类型更改为:
import { UnpackNestedValue, UseFormReturn, DeepPartialSkipArrayKey } from "react-hook-form";
import { FormInputs } from "./FormContainer";
interface Props {
register: UseFormReturn["register"];
formData: UnpackNestedValue<DeepPartialSkipArrayKey<FormInputs>>
}
或者,由于您的表单 object(至少在此示例中)非常“简单”(实际上只是键/值对),您可以使用更简单的Partial<FormInputs>
类型声明,它在这种情况下功能等效。
我发现了两件事可以改善和解决您的问题。
useForm
返回的方法watch
而不是useWatch
来获取完整的表单数据。 您可以将useWatch
用于单个表单输入更改,而不会影响根组件的呈现。// Empty watch function will return the full form data.
const formData = watch()
watch
返回完整的表单数据,因此FormView
组件中的 prop 将是FormInputs
。interface Props {
register: UseFormReturn["register"];
formData: FormInputs;
}
这应该可以修复您的 TS 错误。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.