Implementación de Layouts Compartidos en Angular para Vistas Anidadas
Resumen
¿Cómo estructurar sitios web con Angular utilizando layouts compartidos?
Cuando construimos un sitio web, especialmente uno grande como un e-commerce, la organización y mantenimiento del código es fundamental. Angular ofrece una solución eficiente a este desafío: los layouts compartidos. Esta técnica ofrece una manera estructurada de gestionar el contenido y la disposición de las páginas de manera eficiente.
¿Qué problema resuelve el uso de layouts compartidos?
La repetición de código es un problema común cuando el sitio crece y se necesitan más páginas. Imagina tener una estructura básica que se repite en cada página: un container, header y contenido. Realizar un cambio en esta estructura puede volverse tedioso si se debe modificar manualmente cada página. Aquí es donde entran en juego los layouts compartidos.
Angular permite crear una estructura común que las páginas pueden compartir, manteniendo solo el contenido específico a nivel individual. Así, podemos ajustar el layout base en un solo lugar y aplicar los cambios globalmente a todas las páginas que lo usan.
¿Cómo crear un layout compartido en Angular?
Para implementar layouts compartidos, comenzaremos por crear un componente llamado layout. Aquí pondremos la estructura básica que se repite. Este componente actuará como un contenedor de otras páginas.
ng generate component shared/components/layout
Una vez creado, añadiremos la parte repetitiva del layout como el header y, opcionalmente, un footer. Colocaremos un router-outlet para determinar dónde se inyectará el contenido específico de cada página.
Para que funcione correctamente, debemos configurar los routes y especificar que ciertas rutas usan este layout. El siguiente paso sería agregar un nuevo path base en la configuración de routing e incluir un array de rutas hijas (children) que adoptan este layout.
Así, conseguimos una estructura anidada donde el layout actúa como contenedor de estas rutas hijas. Las páginas solo manejan su contenido exclusivo, haciendo que los cambios en el layout se propaguen automáticamente.
¿Cómo optimizar el código eliminando redundancias?
A menudo, con layouts compartidos, es común olvidar limpiar las páginas individuales de códigos redundantes. Por ejemplo, ya no es necesario mantener un header en cada página de home o about, ya que estos componentes se manejan en el layout compartido.
// Antes de usar layout compartido<app-header></app-header><div>Contenido específico de la página</div>// Después de usar layout compartido<div>Contenido específico de la página</div>
¿Qué ventajas ofrece la organización del código mediante layouts?
La implementación de layouts compartidos brinda una serie de ventajas importantes:
Mantenimiento Simplificado: Un cambio en el diseño o estilo se aplica globalmente.
Eficiencia: Las páginas mantienen solo el contenido específico, reduciendo redundancias.
Escalabilidad: A medida que la aplicación crece, se mantiene organizada y se simplifica la extensión.
Si estás desarrollando con Angular, la adopción de layouts compartidos no solo te ahorrará tiempo, sino que también mejorará la arquitectura de tu aplicación. Al enfocar cambios en un solo punto de control, tu sitio no solo es más fácil de gestionar, sino que también es más resistente a errores y más rápido de desarrollar. ¡Anímate a integrar esta técnica en tus proyectos y experimenta la mejora en la eficiencia!
Si estas usando Angular 18 o superior, ten esto en cuenta
¿Por qué importar RouterOutlet y no RouterModule?
En las versiones más recientes de Angular, al usar standalone components, Angular te permite importar solo las partes específicas del módulo que realmente necesitas. Dado que solo estás utilizando el router-outlet, no es necesario importar todo el RouterModule. Esto mejora la modularidad y el rendimiento de tu aplicación, importando solo lo que usas.
✅
¿Y si mi header tiene diferentes comportamientos dependiendo del path aun se podría aplicar esto de vistas anidadas?
Es decir por ej. en el path "/" mi header puede tener un input de búsqueda pero si voy al path "/busqueda" en mi header ese input ya no debería aparecer.
Buenas pregunta! Podrías colocar un if de renderizado según el path, también soy nuevo en Angular, pero es lo que haría en React, me imagino que aquí también se podrá realizar algo parecido, esa lógica iría en el archivo ts de tu header
Lo mejor es dividir el header en componentes, en este caso sería:
Logo
Menu
SearchInput
CartButton
Le creas un @Input al componente Header para indicarle cuales serían los subcomponentes que serían visibles y dependiendo la vista los puedes mostrar u ocultar.
Excelente feature, esta parte de las vistas anidadas las había escuchado pero no las había aplicado antes, muy interesante y sencillo de aplicar, además de la facilidad para hacer mantenimiento de la app.
¿Puedo también colocar otro <router-outlet /> dentro de un componente interno?, ¿Estaría correcto hacerlo?, estaría colocando otra sección children dentro de un componente que ya está en un children.
De poder, puedes hacerlo, pero no se me ocurre algún caso real donde necesites ocuparlo la verdad