Optimización de Aplicaciones con Lazy Loading y Code Splitting

Clase 67 de 71Curso de Angular: Creación de Aplicaciones Web

Resumen

¿Qué es Lazy Loading y Code Splitting?

El concepto de Lazy Loading y Code Splitting es fundamental para mejorar el rendimiento de tus aplicaciones web. Estas prácticas se relacionan con reducir el tamaño de la aplicación para que cargue más rápido. Cuando una aplicación es más ligera, se reduce el tiempo que tardan en descargarse, parsearse, compilarse y ejecutarse los archivos de JavaScript, lo que mejora la velocidad global de la aplicación.

¿Cómo funcionan las peticiones en la web?

Cada vez que tu navegador solicita una página web, generalmente escrita en HTML, realiza un "initial request". Este "initial request" busca hacia el servidor donde se encuentra la página y la obtiene. Durante este proceso, el navegador empieza a leer el HTML y busca referencias a otros recursos como CSS, JavaScript, e imágenes, solicitándolos al servidor conforme los encuentra.

¿Qué pasa con los archivos JavaScript?

  • Descarga: Solicita el archivo al servidor y lo descarga.
  • Parseo: Analiza la estructura del archivo JavaScript.
  • Compilación: Convierte el código para que pueda ser ejecutado por la máquina.
  • Ejecución: Finalmente ejecuta el código.

El tiempo más importante se gasta en la descarga, que depende del tamaño del archivo y de la velocidad de conexión. Aquí es donde el peso del archivo JavaScript se convierte en un factor crucial para el rendimiento.

¿Cómo ayuda Angular a optimizar el JavaScript?

Angular utiliza un empaquetador que trabaja con el código TypeScript para convertirlo a JavaScript y comprimirlo lo más posible. Sin embargo, cuando no aplicamos técnicas de Lazy Loading o Code Splitting, este proceso genera un archivo llamado main.js que incluye todo el código de la aplicación, haciéndolo muy pesado.

¿Qué es Lazy Loading?

Lazy Loading es una técnica que permite cargar partes del código solo cuando es necesario. En lugar de cargar toda la aplicación de una vez, solo se cargan los componentes requeridos en un momento particular, por lo cual se ahorra ancho de banda y se mejoran los tiempos de carga.

¿Y qué hay del Code Splitting?

Code Splitting complementa al Lazy Loading separando el código en "chunks". Esto implica que el empaquetador divide el archivo principal en varios archivos más pequeños que se cargan conforme el usuario navega por las rutas de la aplicación.

¿Cómo se implementa el Code Splitting con routing?

Una de las técnicas más comunes para implementar Code Splitting es usar routing. Cada ruta en la aplicación tiene asociado un "chunk" particular de código.

¿Cuál es la ventaja de este método?

  • Chunk por cada ruta: A medida que el usuario navega por las diferentes secciones de una aplicación, se cargan los archivos JavaScript necesarios para esa sección específica.

  • Ejecución en el momento adecuado: Los chunks se ejecutan sólo cuando el usuario accede a una página específica, optimizando el uso de recursos y el tiempo de carga.

Esto es particularmente útil porque evita enviar y ejecutar código JavaScript para páginas que el usuario aún no ha solicitado, ahorrando ancho de banda y procesamiento.

En resumen, las técnicas de Lazy Loading y Code Splitting permiten que las aplicaciones sean más rápidas y eficientes, mejorando la experiencia del usuario al reducir el tiempo de carga sin comprometer la funcionalidad. ¡Continúa explorando estas técnicas para transformar tus aplicaciones web!