Skip to content

Latest commit

 

History

History
184 lines (143 loc) · 4.58 KB

forms.md

File metadata and controls

184 lines (143 loc) · 4.58 KB

React JS Forms

Handling forms in React is an essential skill for building interactive web applications. This guide will explore different methods to manage form state and handle form submission, including controlled components, uncontrolled components, and libraries like Formik.

Table of Contents


Introduction to React Forms

Forms in React can manage input from the user, which is often necessary for tasks like login, registration, and data entry.

Controlled Components

Controlled components are those where React controls the form data. In these components, form data is handled by the state within the component.

Example:

import React, { useState } from 'react';

const Form = () => {
  const [inputValue, setInputValue] = useState('');

  const handleChange = (event) => {
    setInputValue(event.target.value);
  };

  const handleSubmit = (event) => {
    event.preventDefault();
    alert('A name was submitted: ' + inputValue);
  };

  return (
    <form onSubmit={handleSubmit}>
      <label>
        Name:
        <input type="text" value={inputValue} onChange={handleChange} />
      </label>
      <button type="submit">Submit</button>
    </form>
  );
};

In this example, the form is controlled via state. Every state mutation will have an associated handler function.

Uncontrolled Components

Uncontrolled components are those where form data is handled by the DOM itself. React does not control the state of the inputs.

Example:

import React, { useRef } from 'react';

const Form = () => {
  const inputRef = useRef();

  const handleSubmit = (event) => {
    event.preventDefault();
    alert('A name was submitted: ' + inputRef.current.value);
  };

  return (
    <form onSubmit={handleSubmit}>
      <label>
        Name:
        <input type="text" ref={inputRef} />
      </label>
      <button type="submit">Submit</button>
    </form>
  );
};

This form uses useRef to access the DOM node directly, which is typical for uncontrolled components.

Using Formik

Formik is a popular library to help manage form state, validation, and submission in React.

Example:

import React from 'react';
import { useFormik } from 'formik';

const Form = () => {
  const formik = useFormik({
    initialValues: {
      name: '',
    },
    onSubmit: values => {
      alert('A name was submitted: ' + values.name);
    },
  });

  return (
    <form onSubmit={formik.handleSubmit}>
      <label>
        Name:
        <input
          type="text"
          name="name"
          onChange={formik.handleChange}
          value={formik.values.name}
        />
      </label>
      <button type="submit">Submit</button>
    </form>
  );
};

Formik simplifies the form handling by taking care of the repetitive and complex parts of form state management and validation.

Validation Techniques

Validating form input is crucial to maintaining data integrity.

Example using Formik with Yup:

import React from 'react';
import { useFormik } from 'formik';
import * as Yup from 'yup';

const validationSchema = Yup.object({
  name: Yup.string()
    .required('Required')
    .min(2, 'Too Short!'),
});

const Form = () => {
  const formik = useFormik({
    initialValues: {
      name: '',
    },
    validationSchema,
    onSubmit: values => {
      alert('Form Submitted');
    },
  });

  return (
    <form onSubmit={formik.handleSubmit}>
      <label>
        Name:
        <input
          type="text"
          name="name"
          onChange={formik.handleChange}
          onBlur={formik.handleBlur}
          value={formik.values.name}
        />
        {formik.touched.name && formik.errors.name ? (
          <div>{formik.errors.name}</div>
        ) : null}
      </label>
      <button type="submit">Submit</button>
    </form>
  );
};

This example integrates Yup for schema validation, providing error messages and form validation rules.

Best Practices

  • Use Controlled Components for Predictable State: Controlled components are easier to debug and integrate with complex UIs.
  • Use Uncontrolled Components for Simplicity and Performance: When you need simple forms without complex interactions.
  • Leverage Libraries like Formik: These libraries simplify form handling and validation.
  • Always Validate User Input: To ensure data integrity and user feedback.

[EOF]