Hooks integrados en React

Los Hooks te dejan usar diferentes características de React de sus componentes. Puedes también usar los Hooks integrados o combinarlos para crear el tuyo. Esta página enumera todos los Hooks integrados en React.


Hooks de estado

El Estado permite a un componente «recordar» información como el input del usuario. Por ejemplo, un componente de formulario puede usar el estado para almacenar el valor de entrada, mientras que un componente de galería de imágenes puede usar el estado para almacenar el indicé de la imagen seleccionada.

Para añadir un estado a un componente, usa de estos Hooks:

function ImageGallery() {
const [index, setIndex] = useState(0);
// ...

Hooks de Contexto

El Contexto permite a un componente recibir información desde un componente padre distante sin pasarsela como props. Por ejemplo, tu componente en el nivel más alto de tu aplicación puede pasar el tema de interfaz de usuario actual a todos los componentes debajo, no importa que tan profundo estén.

function Button() {
const theme = useContext(ThemeContext);
// ...

Hooks Ref

Los Refs permiten a un componente conserva algo de información que no es usada para el renderizado, como un nodo del DOM or el ID de un timeout. A diferencia del estado, actualizar un ref no no vuelve a renderizar tu componente. Los refs son una «puerta de escape» del paradigma de React. Son útiles cuando necesitas trabajar con sistemas que no son de React, como son las APIs integradas del navegador.

  • useRef declara un ref. Puedes conservar cualquier valor en él, pero más frecuentemente se utiliza para conservar un node del DOM.
  • useImperativeHandle te permite personalizar el ref expuesto por tu componente. Es raramente utilizado.
function Form() {
const inputRef = useRef(null);
// ...

Hooks de Efecto

Los Efectos permiten a un componente conectarse y sincronizarse con sistemas externos. Esto incluye lidiar con la red, el DOM del navegador, animaciones, widgets escritos usando una biblioteca UI distinta, y otro código que no sea de React.

  • useEffect conecta un componente a un sistema externo.
function ChatRoom({ roomId }) {
useEffect(() => {
const connection = createConnection(roomId);
connection.connect();
return () => connection.disconnect();
}, [roomId]);
// ...

Los Efectos son una «puerta de escape» del paradigma de React. No utilices los Efectos para orquestar el flujo de los datos de tu aplicación. Si no estas interactuando con un sistema externo, puede que no necesites un Efecto.

Hay dos variaciones raramente usadas de useEffect con diferencias en la sincronización:

  • useLayoutEffect se activa antes de que el navegador vuelve a pintar la pantalla. Puedes medir la maquetación aquí.
  • useInsertionEffect se activa antes de que React realice cambios al DOM. Las bibliotecas pueden insertar CSS dinámico aquí.

Hooks de rendimiento

Una forma común de optimizar el rendimiento del re-renderizado es saltarse el trabajo innecesario. Por ejemplo, puedes decirle a React que reutilice cálculos que están en la cache o que se salte un re-renderizado si los datos no han cambiado desde el renderizado anterior.

Para saltarse cálculos y re-renderizados innecesarios, usa uno de estos Hooks:

  • useMemo te permite almacenar en caché el resultado de un cálculo costoso.
  • useCallback te permite almacenar en caché la definición de una función antes de pasarla a un componente optimizado.
function TodoList({ todos, tab, theme }) {
const visibleTodos = useMemo(() => filterTodos(todos, tab), [todos, tab]);
// ...
}

A veces, no podrás saltarte re-renderizados porque la pantalla realmente necesita actualizarse. En ese caso, puede mejorar el rendimiento separando actualizaciones bloqueantes que deben ser síncronas (como escribir en un input) desde actualizaciones no bloqueantes las cuales no necesitan bloquear la interfaz de usuario (como actualizar una gráfica).

Para priorizar el renderizado, usa uno de estos Hooks:

  • useTransition te permite marcar un estado de transición como no bloqueante y permite a otras actualizaciones interrumpirlo.
  • useDeferredValue te permite aplazar la actualización de una parte no critica de la UI y permite a las otras partes actualizarse primero.

Otros Hooks

Estos Hooks son mayormente útiles para los autores de bibliotecas y no son comúnmente utilizados para el código de una aplicación.

  • useDebugValue te permite personalizar la etiqueta que las herramientas de desarrollo de muestran para tu Hook personalizado.
  • useId permite a un componente se asocie a sí mismo un identificador único. Típicamente es usado con APIs de accesibilidad.
  • useSyncExternalStore permite a un componente suscribirse a una store externo.

Tus propios Hooks

Puedes también definir tus propios Hooks personalizados como funciones de JavaScript.