Clue Mediator

Create a simple form in React using react-hook-form

📅January 4, 2023

Today, we’ll show you how to create a simple form in React using react-hook-form package. In the previous article, we have explained validation-in-reactjs" title="Form Validation in ReactJS">how to create a form without any package in React.

In this form example, we will use a very popular library to build a form and in the upcoming examples, we’ll show you how to validate it.

Demo Application

Output - Create a simple form in React using react-hook-form - Clue Mediator

Output - Create a simple form in React using react-hook-form - Clue Mediator

Create a simple form in React using react-hook-form

  1. Project structure
  2. Package dependencies
  3. Design a simple form
  4. Integrate the react-hook-form
  5. Output

1. Project structure

Refer to the following React project structure for the form example.

  • form-using-react-hook-form

    • node_modules

    • public

      • index.html
    • src

      • App.js
      • index.css
      • index.js
    • package-lock.json

    • package.json

    • README.md

2. Package dependencies

In this example, we have to install the react-hook-form npm package. Run the following command to install the `react-hook-form`.

npm i react-hook-form

You will find the version of following packages in React application.

react

^18.2.0

react-hook-form

^7.41.3

3. Design a simple form

To start with, we will create a simple form design and store the data on click of the submit button.

App.js

import React, { useState } from 'react';

function App() {
  const [data, setData] = useState();

  const onSubmit = () => {

  }

  return <form onsubmit={onSubmit}>
    <h4>Form using react-hook-form - <a href="https://www.cluemediator.com/" target="_blank" rel="noopener noreferrer">Clue Mediator</a></h4>
    <div>
      <label>Name</label>
      <input placeholder="Name">
    </div>
    <div>
      <label>Email</label>
      <input placeholder="Email">
    </div>
    <div>
      <label>Website</label>
      <input placeholder="Website">
    </div>
    <div>
      <button>Submit</button>
    </div>
    {data && <pre>{JSON.stringify(data, null, 2)}</pre>}
  </form>
}

export default App;

Here, we have added three different fields named `name`, `email`, and `website`. At the end of the form we are displaying the form values on the page.

4. Integrate the react-hook-form

Now, let’s integrate the `react-hook-form` in the above form. We have to add the following code in the existing form.

import { useForm } from 'react-hook-form';

function App() {
  const { register, handleSubmit } = useForm();

  const onSubmit = (formData) => {
    setData(formData);
  }

  return <form onsubmit={handleSubmit(onSubmit)}>
    ...
    ...
    <input placeholder="Name" {...register('name')}="">
    ...
    ...
    <input placeholder="Email" {...register('email')}="">
    ...
    ...
    <input placeholder="Website" {...register('website')}="">
    ...
    ...
  </form>
}

export default App;

In the above code, we have used the `register()` method to register the fields and used the `handleSubmit()` method to get the submitted data on submit. Both the methods, we have exported from the `useForm()`.

5. Output

Let's put all the code together and see how it looks.

App.js

import React, { useState } from 'react';
import { useForm } from 'react-hook-form';

function App() {
  const [data, setData] = useState();
  const { register, handleSubmit } = useForm();

  const onSubmit = (formData) => {
    setData(formData);
  }

  return <form onsubmit={handleSubmit(onSubmit)}>
    <h4>Form using react-hook-form - <a href="https://www.cluemediator.com/" target="_blank" rel="noopener noreferrer">Clue Mediator</a></h4>
    <div>
      <label>Name</label>
      <input placeholder="Name" {...register('name')}="">
    </div>
    <div>
      <label>Email</label>
      <input placeholder="Email" {...register('email')}="">
    </div>
    <div>
      <label>Website</label>
      <input placeholder="Website" {...register('website')}="">
    </div>
    <div>
      <button>Submit</button>
    </div>
    {data && <pre>{JSON.stringify(data, null, 2)}</pre>}
  </form>
}

export default App;

Run the application and check the output in the browser.

That’s it for today.
Thank you for reading. Happy Coding..!! 🙂

Demo & Source Code

GitHub Repository StackBlitz Project