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?
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
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With