DEV Community

Cover image for 🧠 Understanding React Hooks – The Modern Way to Write React
Rishabh Joshi
Rishabh Joshi

Posted on

🧠 Understanding React Hooks – The Modern Way to Write React

In React, Hooks are special functions that let you "hook into" React’s features like state, context, refs, and lifecycle methods — all without writing a class.

They were introduced in React 16.8 and completely changed the way developers write components.


🚀 Why Hooks?

Before Hooks, managing component state and lifecycle logic meant using class components. This led to verbose, harder-to-test code and limited reusability.
Hooks make it possible to write cleaner, reusable, and more maintainable code inside functional components.


🔍 What Exactly Are Hooks?

Hooks are built-in functions that allow us to access React’s internal capabilities:

📦 Creating and accessing state from the Fiber tree
🔁 Registering side effects (e.g., data fetching, DOM updates)
🧱 Direct interaction with the DOM or values that persist across renders
They essentially “hook” into the React internals — hence the name.


📏 Rules of Hooks

To make hooks work correctly, React enforces two strict rules:

  1. Only call Hooks at the top level

    • ✅ Do: useState() at the top of your component
    • ❌ Don’t: call hooks inside loops, conditions, or nested functions
    • This ensures that hooks are always called in the same order on every render.
  2. Only call Hooks from React functions

    • Call hooks only inside functional components or custom hooks
    • Do not call them in regular JavaScript functions or class components

🧠 These rules are crucial because React relies on the order of hook calls to manage state internally.


⚙️ Commonly Used React Hooks

Here are the most frequently used hooks you’ll encounter when building React apps:

1️⃣ useState – Manages Local State
Allows you to add state to a functional component.

const [count, setCount] = useState(0);
Enter fullscreen mode Exit fullscreen mode

2️⃣ useEffect – Handles Side Effects
Performs tasks like data fetching, subscriptions, or DOM manipulations.

useEffect(() => {
  document.title = `Count: ${count}`;
}, [count]);
Enter fullscreen mode Exit fullscreen mode

3️⃣ useRef – Access DOM Elements & Persist Values
Used to get references to DOM nodes or persist mutable values without triggering re-renders.

const inputRef = useRef(null);
Enter fullscreen mode Exit fullscreen mode

4️⃣ useReducer – Advanced State Management
Ideal for managing complex state logic or multiple related state variables.

const [state, dispatch] = useReducer(reducerFn, initialState);
Enter fullscreen mode Exit fullscreen mode

5️⃣ useContext – Manages Global State
Access shared values without prop drilling via the React Context API.

const theme = useContext(ThemeContext);
Enter fullscreen mode Exit fullscreen mode

🔄 Why Hooks Must Be Called in the Same Order

React keeps track of hooks using an internal array — one for each component.

Hooks are stored in an array in the order they are called. When the component re-renders, React reuses the hooks in the exact same order. Since hooks don’t have unique identifiers, React assumes that each re-render will call hooks in the same order.

If hooks are called in different orders on different renders (say, conditionally), React won’t be able to match them up correctly. This causes bugs or warnings like:

"Rendered fewer hooks than expected..."

So remember:

  • ❌ Avoid calling hooks inside if statements or loops
  • ✅ Always call hooks unconditionally at the top level of your component or custom hook

✨ Final Thoughts

Hooks have reshaped the React landscape — making it more functional, declarative, and elegant. They encourage separation of concerns, cleaner codebases, and better component composition.

Whether you're just starting with React or building production-grade apps, mastering Hooks is essential for writing modern React code.


🙌 Let’s Connect

I’d love to hear your thoughts, questions, or feedback.
You can reach me on GitHub or leave a comment below.

Top comments (0)