Issues with creating forms in React

Let’s explore some of the problems that can arise during the various stages of form development in React, particularly when dealing with larger forms.

Managing the form state

When creating a React form the traditional way, we need to set up states to keep track of the values and errors in each of our form fields. We also need to keep track of the touched state so we know the input fields that have been visited.

As the form gets bigger, we have more fields, and this increases the size of our state. This is because for each field we’re tracking, at least three states—the value of the field, the touched state, and the error state. All of these states make the form more difficult to manage.

Validating form values

We used multiple if statements to test for different possible validation constraints of each field. More fields in our form mean more validation constraints. This means we’ll have even more if and nested if statements. You can imagine how complicated our code base becomes when this happens.

Submitting the form

If we disable the default validation behavior of our form using the novalidate attribute in the <form> tag, clicking the “Submit” button submits the form whether or not error messages are displayed. To fix this, we have to call the submission logic conditionally. We can write a condition that ensures there are no error messages in any of the fields in the state and no invalid fields.

Get hands-on with 1300+ tech skills courses.