Couldn't find a solution.
I'm using react-hook-form
and I want to disable the submit button when the forms are empty and enable as long as all forms have atleast something written in them.
How would I do that using react-hook-form
?
The best solution I found so far using formState
and by setting the mode to onChange
.
const { register, handleSubmit, formState } = useForm({
mode: "onChange"
});
And on the submit button:
<button disabled={!formState.isValid}/>
Based on this issue: https://github.com/react-hook-form/react-hook-form/issues/77
onChange mode explanation from the documentation:
Validation will trigger on the change event with each input, and lead to multiple re-renders. Warning: this often comes with a significant impact on performance.
const {
register,
handleSubmit,
formState: { isSubmitting, isDirty, isValid } // here
} = useForm({ mode: "onChange" })
<button
type="submit"
disabled={!isDirty || !isValid} // here
>
Comment
</button>
you can use formState
=> isDirty
which means form is been modified.
https://react-hook-form.com/api#formState
here is a working example for formState
below:
https://codesandbox.io/s/react-hook-form-v6-formstate-ht098?file=/src/index.jsx:423-432
<input disable={formState.isDirty} type="submit" />
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With