Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

When would I not pass a dependency list in React useEffect?

in what case I shouldn't put the empty array [] as dependcies in react useEffect? like

React.useEffect(() => {
    if (true) {
      doStuff()
    }
    return () => null;
  });

Is above code even valid?

like image 895
Nadiely Jade Avatar asked Oct 14 '25 17:10

Nadiely Jade


2 Answers

just remember 3 rules:

useEffect(()=>{},[]) //this is like componentDidMount
useEffect(()=>{}) //this will run every render
useEffect(()=>{},[dep1, dep2]) //this will run if one on de dependency change
like image 76
claud.io Avatar answered Oct 17 '25 09:10

claud.io


Your code is valid.

undefined is passed as dependencies and it means useEffect runs on every render. So if you want to do some work that shouldn't be run on every render (like adding event listener), you should give a dependency array.

like image 23
baymax Avatar answered Oct 17 '25 11:10

baymax



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!