POLITICA DE COOKIES

Q2BSTUDIO.COM utiliza cookies técnicas, analíticas, de sesión y de publicidad con la finalidad de prestar un mejor servicio. No obstante, necesitamos su consentimiento explícito para poder utilizarlas. Así mismo puede cambiar la configuración de las cookies u obtener más información aquí .

El arte de evitar la doble ejecución de useEffect en modo estricto

Cómo evitar la doble ejecución de useEffect en modo estricto

Publicado el 17/08/2025

Descubre 100 plus posibilidades poderosas con React Hooks. Visita www.reactuse.com para documentación completa con soporte MCP Model Context Protocol o instala mediante npm install @reactuse/core para potenciar la eficiencia en tu desarrollo React con una amplia colección de hooks

Prefacio Cuando tus efectos secundarios tienen un gemelo

Alguna vez has creado una sola llamada a una API y en el panel de red vez dos solicitudes idénticas Durante el desarrollo tu contador diseñado para incrementarse una sola vez empieza a contar desde 2 Bienvenido al mecanismo de doble ejecución de React 18 en Strict Mode

Strict Mode La comprobacion extra de React

Strict Mode actua como un verificador que ejecuta efectos para detectar efectos impuros de forma anticipada Esto ayuda a escribir componentes mas robustos pero en escenarios reales a menudo necesitamos que ciertas operaciones se ejecuten solamente una vez por aplicacion o por referencia de funcion Ejemplos comunes envio de analitica inicializacion de librerias de terceros registro de eventos globales y logging de comportamiento de usuario

El problema aparece cuando useEffect con array de dependencias vacio se ejecuta dos veces en modo estricto y provoca duplicados en acciones que deberian ser unicas

Soluciones tradicionales y sus inconvenientes

Solucion 1 uso de useRef Un patron comun es usar useRef para marcar que el efecto ya se ejecuto pero esto genera mucho codigo repetitivo y debe replicarse en cada componente donde se requiere ejecucion unica

Solucion 2 bandera global Otra opcion es usar una variable global para evitar reejecuciones Esto contamina el ambito global y causa interferencias entre instancias de componentes semejante a compañeros de piso que comparten la misma nevera

Por que no envolver useRef en un hook personalizado El enfoque con useRef parece natural pero introduce ambiguedades con los cambios de dependencias y complejidad para gestionar cuando resetear el marcador hasRun Estas cuestiones complican la semantica y la gestion de memoria

Solucion elegante crear createOnceEffect

Una alternativa mas limpia es registrar referencias de la funcion de efecto usando WeakSet La idea es simple Registrar la referencia de la funcion cuando se ejecuta por primera vez y bloquear ejecuciones posteriores para la misma referencia de funcion Esto evita la polucion global y permite recoleccion de basura automatica cuando la referencia deja de existir

Implementacion conceptual WeakSet record new WeakSet createOnceEffect hook devuelve un hook que toma effect y deps dentro se crea onceWrapper que verifica shouldStart=!record.has(effect) si shouldStart entonces record.add(effect) y return effect() luego se llama hook con una funcion que hace return onceWrapper() y las deps correspondientes Este patron permite crear useOnceEffect a partir de useEffect y useOnceLayoutEffect a partir de useLayoutEffect

Por que WeakSet ventajas principales

Unicidad global basada en la referencia de la funcion la misma funcion se ejecuta solo una vez independientemente de la instancia de componente Recoleccion de basura automatica sin fugas de memoria Semantica clara la misma referencia de efecto se ejecuta una sola vez Cero configuracion extra no hay que preocuparse por comparar arrays de dependencias Mejor rendimiento operaciones O1 para busqueda y adicion

Como funciona en la practica piensa en cada funcion de efecto como si tuviera una identificacion cuando intenta ejecutarse una segunda vez el portero del WeakSet detecta que ya fue registrada y evita la ejecucion

Uso practico ejemplo conceptual sustituye useEffect por useOnceEffect para enviar analitica de pagina inicializar SDKs de terceros o registrar listeners globales El cleanup sigue funcionando normalmente cuando el componente se desmonta

Extension para useLayoutEffect cuando necesitas ejecutar operaciones sincronicamente antes de actualizaciones DOM pero solamente una vez createOnceEffect aplicado a useLayoutEffect ofrece esa garantia

Limitaciones y buenas practicas

Las arrays de dependencias siguen siendo importantes incluso para ejecuciones unicas Debes elegir useOnceEffect solo para escenarios que realmente requieren ejecucion global una sola vez Las funciones de limpieza retornadas se ejecutan con el flujo habitual al desmontar componentes

Solucion lista para usar Si prefieres no implementarlo ReactUse ya ofrece useOnceEffect en su libreria consulta reactuse efecto useOnceEffect o instala npm install @reactuse/core y usa import useOnceEffect from @reactuse/core

Conclusiones La doble ejecucion de Strict Mode busca mejorar el codigo detectando efectos impuros pero puede causar comportamientos duplicados en tareas que deben ejecutarse una sola vez El enfoque con WeakSet y createOnceEffect proporciona una solucion elegante clara y eficiente que mantiene el codigo legible y evita boilerplate innecesario

Sobre Q2BSTUDIO

Q2BSTUDIO es una empresa de desarrollo de software aplicaciones a medida y soluciones tecnologicas especializada en inteligencia artificial ciberseguridad y servicios cloud aws y azure Ofrecemos servicios inteligencia de negocio implementacion de power bi y soluciones de ia para empresas incluyendo agentes IA y automatizacion a medida Nuestra experiencia abarca software a medida aplicaciones a medida integraciones cloud y estrategias de ciberseguridad para proteger datos y servicios Gestionamos proyectos de inteligencia artificial para empresas creando agentes IA personalizados que mejoran procesos y experiencia de usuario

Servicios destacados de Q2BSTUDIO

Desarrollo de software a medida y aplicaciones a medida Consultoria y despliegue en servicios cloud aws y azure Proyectos de inteligencia artificial y servicios inteligencia de negocio Implementacion de power bi para analitica avanzada y visualizacion Desarrollo e integracion de agentes IA Soluciones de ciberseguridad y auditorias para cumplir con los requisitos regulatorios

Palabras clave para mejorar posicionamiento aplicaciones a medida software a medida inteligencia artificial ciberseguridad servicios cloud aws y azure servicios inteligencia de negocio ia para empresas agentes IA power bi

Si necesitas ayuda para implementar patrones solidos en React como evitar la doble ejecucion de useEffect o quieres desarrollar una aplicacion a medida con capacidades de inteligencia artificial y seguridad contacta a Q2BSTUDIO podemos acompañarte desde la concepcion hasta la entrega incluyendo despliegue en servicios cloud aws y azure integracion de power bi y creacion de agentes IA para empresas

Probar este enfoque te permitira reducir duplicidades mejorar la claridad del codigo y aprovechar soluciones elegantes de JavaScript para problemas practicos Cuando te encuentres con el gemelo de Strict Mode recuerda que hay formas limpias y mantenibles de gestionarlo

Fin del artículo, inicio de la diversión
Construyendo software juntos

Dando vida a tus ideas desde 2008

Diseñamos aplicaciones móviles y de escritorio innovadoras que cumplen con tus requisitos específicos y mejoran la eficiencia operativa.
Más info
Cuéntanos tu visión
Sea cual sea el alcance, podemos convertir tu idea en realidad. Envíanosla y charlemos sobre tu proyecto o una colaboración futura.
Contáctanos
artículos destacados
Live Chat
Enviado correctamente.

Gracias por confiar en Q2BStudio