Things to Avoid

Hooks don't work inside classes.

Don't call Hooks inside loops, conditions, or nested functions. Instead, always use Hooks at the top level of your React function before any early returns. By following this rule, you ensure that Hooks are called in the same order each time a component renders. That's what allows React to correctly preserve the state of Hooks between multiple useState and useEffect calls.