Maximum update depth exceeded warning in React

Last updated : August 28, 2022

This warning can often happen when a component sets the state inside the useEffect hook. The useEffect hook either does not have a dependency array or has the changing state variable as a dependency. That makes the useEffect hook execute in an infinite loop.

useEffect without dependency array

Take a look at the below code. I have a useEffect with no dependency array. That means the effect runs for every component re-render.

import { useEffect, useState } from "react"
export const Person = () =>{
  const [inputType, setInputType] = useState<boolean>(false)
  useEffect(() => {
    setInputType(prev => !prev) // Creates an infinite loop
  })
 return(
  <>
  {inputType}
  </>
 )
}

When the component renders for the first time, the useEffect executes and sets the inputType to the opposite value it had before. That causes a component re-render because the setInputType(prev => !prev) results in a state update and guarantees another useEffect execution. This cycle creates an infinite loop.

Having a changing state variable as a dependency

In this scenario, I do have a dependency array. But my dependency array contains one of the state variables that I change inside the useEffect hook.

import { useEffect, useState } from "react"
export const Person = () =>{
  const [inputType, setInputType] = useState<boolean>(false)
  useEffect(() => {
    setInputType(prev => !prev)
  },[inputType]) // Creates an infinite loop
 return(
  <>
  {inputType}
  </>
 )
}

Note that I have the inputType state variable in the dependency array while I update the same variable in the useEffect hook. This scenario creates the same infinite loop as the previous example did.

How to avoid the "Maximum update depth exceeded" warning?

If your useEffect hook updates state variables, always use a dependency array as the second argument to the useEffect hook. Do not use state variables you update inside the useEffect hook as arguments in the dependency array. If you don't have any qualifying dependencies, use an empty array to avoid infinite loops.

L Raney
By: L Raney
Lance is a software engineer with over 15 years of experience in full-stack software development.
Read more...

Comments are disabled

No Comments