Hooks
O react possibilita a criação de componentes. Mas e quando queremos que o html renderizado pelo componente seja atualizado junto com alguma variável do javascript? Nos componentes funcionais (sem ser feitos com classes), usamos os hooks.
Um problema:
Queremos fazer um contador, onde sempre que um botão é clicado, um número que aparece na tela aumenta. Porém, podemos ver que isso não funciona:
useState
Função que recebe um estado inicial e retorna uma variável e um setter.
Serve para declarar variáveis com as quais se deseja sincronizar o conteúdo da página. Por exemplo:
useEffect
Função que recebe um callback (arrow function) e um array de dependências. Quando o componente for rerenderizado, se alguma das variáveis do array de dependências tiver mudado, o callback é executado.
Serve principalmente para sincronizar um efeito com alguma mudança de variável. Por exemplo:
Atenção: se o useEffect não tiver array de dependêcia, a partir do react 18, ele roda com a mudança de qualquer estado no componente, o que pode gerar um useEffect rodando infinitamente até crashar seu servidor.
useContext
Serve para criar um contexto. Considere uma aplicação web inteira que é baseada num usuário logado. Usando o que conhecemos até agora, teríamos que guardar o usuário na raíz da aplicação e passar pra todos os filhos que precisam (praticamente todos) o usuário e funções (como a de login) por props. Mas e se pudéssemos fazer um estado global, acessível sem ser apenas pelas props? É exatamente isso que é o contexto.
Exemplos: https://codesandbox.io/s/usecontext-demo-qtugvt?file=/src/contexts/UserContext.js https://www.youtube.com/watch?v=Zz4icNdPzTM
Last updated