¿Qué es React.memo y cómo usarlo?

| Última modificación: 6 de junio de 2024 | Tiempo de Lectura: 3 minutos

Algunos de nuestros reconocimientos:

Premios KeepCoding

En el emocionante mundo del desarrollo web, la optimización y el rendimiento son aspectos cruciales a tener en cuenta. Cuando se trata de construir aplicaciones web eficientes con React, una de las herramientas que pueden marcar la diferencia es React.memo. En este artículo, exploramos qué es React.memo y cómo puedes usarlo para mejorar el rendimiento de tus componentes en tus proyectos de desarrollo web.

¿Qué es React.memo?

Es una función incorporada en React que permite optimizar el rendimiento de tus componentes funcionales. Básicamente, lo que hace es memorizar un componente y sus resultados para evitar su recalculación innecesaria. Esto puede ser especialmente útil cuando tienes componentes que se vuelven a renderizar con frecuencia, ya que puede ayudarte a reducir la carga en tu aplicación y mejorar la experiencia del usuario.

¿Cómo funciona React.memo?

Cuando utilizas React.memo en un componente, React guarda una copia de las props pasadas al componente y compara estas props con las nuevas cada vez que el componente se actualiza. Si las props son iguales, React evita la renderización innecesaria del componente y utiliza el resultado memorizado en su lugar.

Veamos un ejemplo para entenderlo mejor:

import React from 'react'; 
function MyComponent(props) { 
// ...código del componente... 
} 
export default React.memo(MyComponent);

En este ejemplo, hemos envuelto nuestro componente MyComponent con React.memo. Ahora, si las props de MyComponent no cambian entre renderizaciones, React usará la versión memorizada del componente en lugar de volver a renderizarlo. Esto puede ahorrar tiempo y recursos de renderización en tu aplicación.

¿Cuándo deberías usar React.memo?

No es necesario usarlo en todos tus componentes, pero puede ser especialmente útil en los siguientes casos:

  1. Componentes con muchas props inmutables: Si tienes componentes que reciben muchas props que rara vez cambian, React.memo puede ayudarte a evitar renderizaciones innecesarias y mejorar el rendimiento de tu aplicación.
  2. Componentes que realizan cálculos costosos: Si tienes componentes que realizan cálculos o operaciones costosas, envolverlos con React.memo puede evitar que esos cálculos se realicen repetidamente cuando las props no cambian.
  3. Componentes que se vuelven a renderizar con frecuencia: Si tienes componentes que se vuelven a renderizar con frecuencia debido a actualizaciones de estado o cambios en otros componentes, React.memo puede ayudarte a reducir la carga en tu aplicación y mejorar la experiencia del usuario.

¿Cómo usar React.memo?

Para usarlo, simplemente envuelve tu componente funcional con React.memo, como te hemos mostrado en el ejemplo anterior. Otra opción es proporcionar un segundo argumento opcional, que es una función de comparación personalizada.

La función de comparación personalizada se utiliza para determinar si las props han cambiado y si el componente debe volver a renderizarse. Si no proporcionas una función de comparación, React utiliza una comparación superficial por defecto para determinar si las props han cambiado.

Veamos un ejemplo de cómo usar una función de comparación personalizada:

import React from 'react'; 
function MyComponent(props) { 
// ...código del componente... 
} 
function arePropsEqual(prevProps, nextProps) { 
// Personaliza la lógica de comparación de props aquí 
return prevProps.id === nextProps.id; 
} 
export default React.memo(MyComponent, arePropsEqual);

En este ejemplo, hemos definido una función arePropsEqual que compara las props id de las versiones previas y siguientes de las props. Si el id es igual, el componente no se volverá a renderizar. Puedes personalizar la lógica de comparación según tus necesidades específicas.

Ejemplo práctico de React.memo

Para ilustrar cómo usar React.memo en un ejemplo práctico, consideremos una aplicación de lista de tareas. Imagina que tienes un componente TaskList que recibe una lista de tareas como props y las muestra en la pantalla. Aquí está cómo podrías aplicar React.memo en este caso:

import React from 'react'; 
function TaskList({ tasks }) { 
return ( 
<div> 
{tasks.map((task) => (
 <Task key={task.id} task={task} /> 
))}
 </div> 
); 
} 
export default React.memo(TaskList);

En este ejemplo, hemos envuelto el componente TaskList con React.memo. Si las tasks pasadas como props no cambian entre renderizaciones, el componente no se volverá a renderizar innecesariamente.

En resumen, React.memo es una herramienta poderosa para mejorar el rendimiento de tus aplicaciones React al evitar renderizaciones innecesarias de componentes funcionales. Puedes utilizarlo en componentes que reciben props inmutables, realizan cálculos costosos o se vuelven a renderizar con frecuencia.

En KeepCoding, entendemos la importancia de dominar las mejores prácticas de desarrollo web, como el uso de React.memo, para avanzar en tu carrera en el sector tecnológico. Si deseas aprender más sobre el desarrollo web y convertirte en un profesional altamente demandado en esta industria, te invitamos a explorar nuestro Desarrollo Web Full Stack Bootcamp. Al finalizar el bootcamp, estarás preparado para enfrentarte a los desafíos del mundo IT, donde se ofrecen salarios competitivos y una gran estabilidad laboral. ¡Entra ya para pedir información y descubre cómo cambiar tu vida en cuestión de meses!

Alberto Casero

Alberto Casero es CTO en Watium, Fundador de Kas Factory & Coordinador del Bootcamp en Desarrollo Web.

Posts más leídos

¡CONVOCATORIA ABIERTA!

Desarrollo web

Full Stack Bootcamp

Conviértete en Full Stack Deeveloper en solo 10 meses. Accede a un sector con el 98,49% de empleabilidad con sueldos de hasta 80K.