Performant, flexible and extensible forms with easy to use validation.
🇦🇺English | 🇨🇳简体ä¸æ–‡ | 🇯🇵日本語 | 🇰🇷한êµì–´ | 🇫🇷Français | 🇮🇹Italiano
- Built with performance and DX in mind
- Uncontrolled form validation
- Tiny size without any dependency
- Follows HTML standard for validation
- Compatible with React Native
- Supports Yup schema-based validation
- Supports native browser validation
- Build forms quickly with the form builder
$ npm install react-hook-form
import React from 'react';
import useForm from 'react-hook-form';
function App() {
const { register, handleSubmit, errors } = useForm(); // initialise the hook
const onSubmit = data => {
console.log(data);
};
return (
<form onSubmit={handleSubmit(onSubmit)}>
<input name="firstname" ref={register} /> {/* register an input */}
<input name="lastname" ref={register({ required: true })} />
{errors.lastname && 'Last name is required.'}
<input name="age" ref={register({ pattern: /\d+/ })} />
{errors.age && 'Please enter number for age.'}
<input type="submit" />
</form>
);
}
Thanks goes to these wonderful people. [Become a contributor].
Thanks goes to all our backers! [Become a backer].