'In useEffect, what's the difference between providing no dependency array and an empty one?
I gather that the useEffect Hook is run after every render, if provided with an empty dependency array:
useEffect(() => {
performSideEffect();
}, []);
But what's the difference between that, and the following?
useEffect(() => {
performSideEffect();
});
Notice the lack of [] at the end. The linter plugin doesn't throw a warning.
Solution 1:[1]
It's not quite the same.
Giving it an empty array acts like
componentDidMountas in, it only runs once.Giving it no second argument acts as both
componentDidMountandcomponentDidUpdate, as in it runs first on mount and then on every re-render.Giving it an array as second argument with any value inside, eg
, [variable1]will only execute the code inside youruseEffecthook ONCE on mount, as well as whenever that particular variable (variable1) changes.
You can read more about the second argument as well as more on how hooks actually work on the official docs at https://reactjs.org/docs/hooks-effect.html
Solution 2:[2]
Just an addition to @bamtheboozle's answer.
If you return a clean up function from your useEffect
useEffect(() => {
performSideEffect();
return cleanUpFunction;
}, []);
It will run before every useEffect code run, to clean up for the previous useEffect run. (Except the very first useEffect run)
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | bamtheboozle |
| Solution 2 | Ankur Marwaha |
