
In React, components can be categorized as controlled or uncontrolled based on how their state is managed. Understanding the difference between these two types of components is important for building efficient and reliable forms and handling user inputs effectively.
1. Controlled Components
A controlled component is a form element (like <input>, <textarea>, or <select>) whose value is controlled by React state. The value of the input is bound to the state, and any changes to the input are handled by React through state updates.
Characteristics of Controlled Components:
- The value of the input is stored in the component’s state.
- React has full control over the value of the form element.
- The state is updated based on user interactions, making the form more predictable and easier to manage.
Example of a Controlled Component:
import React, { useState } from 'react';
function ControlledForm() {
  const [value, setValue] = useState('');
  const handleChange = (event) => {
    setValue(event.target.value);
  };
  const handleSubmit = (event) => {
    event.preventDefault();
    alert(`Form submitted with value: ${value}`);
  };
  return (
    <form onSubmit={handleSubmit}>
      <label>
        Name:
        <input
          type="text"
          value={value} // The value is controlled by React state
          onChange={handleChange} // Updates state on input change
        />
      </label>
      <button type="submit">Submit</button>
    </form>
  );
}
export default ControlledForm;
In this example:
- The value of the <input>is controlled by the state variablevalue.
- Every time the user types, handleChangeupdates the state.
- The form is submitted with the value from the state.
2. Uncontrolled Components
An uncontrolled component is a form element where the value is managed by the DOM itself, rather than React state. In this case, React does not directly manage the form element’s value. Instead, a reference (ref) is used to access the DOM element’s value when needed.
Characteristics of Uncontrolled Components:
- The value of the input is not stored in the component’s state, but in the DOM.
- React does not directly control the value of the form element.
- Refs are used to access the form element’s value.
Example of an Uncontrolled Component:
import React, { useRef } from 'react';
function UncontrolledForm() {
  const inputRef = useRef();
  const handleSubmit = (event) => {
    event.preventDefault();
    alert(`Form submitted with value: ${inputRef.current.value}`);
  };
  return (
    <form onSubmit={handleSubmit}>
      <label>
        Name:
        <input
          type="text"
          ref={inputRef} // Ref used to access the DOM element
        />
      </label>
      <button type="submit">Submit</button>
    </form>
  );
}
export default UncontrolledForm;
In this example:
- The <input>value is not tied to React state.
- Instead, a refis created usinguseRef()to directly access the value from the DOM.
- When the form is submitted, the value is accessed via inputRef.current.value.
3. Controlled vs. Uncontrolled Components: Key Differences
| Feature | Controlled Components | Uncontrolled Components | 
|---|---|---|
| State Management | Form data is managed by React state. | Form data is managed by the DOM. | 
| Value Binding | The value of the input is bound to the state. | The value is not bound to state and is accessed via ref. | 
| Event Handling | Uses event handlers like onChangeto update the state. | Uses refs to get the current value from the DOM. | 
| Control | React has full control over the form elements. | React does not control the form elements directly. | 
| Performance | Can be less performant for very large forms due to frequent re-renders. | May be more performant in certain cases since the DOM handles the updates. | 
| Use Cases | Preferred for complex forms with validation or dynamic updates. | Useful for simple forms or when React state management is not needed. | 
4. Advantages of Controlled Components
- Predictability: Since the form data is always in React state, you can easily access, update, and validate it.
- Form Validation: Controlled components make it easier to implement real-time form validation.
- Conditional Rendering: You can conditionally render input values based on React state.
5. Advantages of Uncontrolled Components
- Simplicity: For simple forms or situations where form data does not need to be tracked continuously in the state, uncontrolled components are simpler to implement.
- Performance: Uncontrolled components can be more performant in scenarios where form data does not need to be directly managed by React, especially for large forms with less interactivity.
6. Choosing Between Controlled and Uncontrolled Components
- Controlled Components: Best suited for forms where you need to:
- Perform real-time validation.
- Update other parts of the UI based on the form values.
- Have complete control over the form data and behavior.
 
- Uncontrolled Components: Best suited for:
- Simple forms with minimal interactivity.
- Situations where form data does not need to be tracked or manipulated in real-time by React.
 
