CursosEmpresasBlogLiveConfPrecios

Optimizando Angular con Lighthouse

Clase 5 de 8 • Laboratorio de Angular: Optimización Web con Lighthouse y SSR

Clase anteriorSiguiente clase

Contenido del curso

Preparación para la prueba

  • 1
    Tu primer día de trabajo como Angular Developer

    Tu primer día de trabajo como Angular Developer

    01:04 min
  • 2
    Setup de Angular para SPAs

    Setup de Angular para SPAs

    04:46 min
  • 3
    Optimiza una landing page con Angular

    Optimiza una landing page con Angular

    08:17 min

Solución de la prueba

  • 4
    Angular con dependencias optimizadas

    Angular con dependencias optimizadas

    02:47 min
  • 5
    Optimizando Angular con Lighthouse

    Optimizando Angular con Lighthouse

    Viendo ahora
  • 6
    Server Side Rendering en Angular

    Server Side Rendering en Angular

    09:26 min
  • 7
    Animaciones en Angular

    Animaciones en Angular

    10:44 min
  • 8
    Próximos pasos

    Próximos pasos

    01:03 min
Tomar examen
Resumen

npm run start:prod

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads
        jose zuñiga

        jose zuñiga

        student•
        hace 2 años

        Les dejo algunas consideraciones y datos de esta clase:

        1. Los algoritmos de compresión solo aceptan formatos de imágenes png y webp. Debes tener tu imagen original en los dos formatos.
        2. Si vas a usar el servidor para build como en la clase es necesario instalar de manera globlal npm install -g http-server
        3. Prefiero usar ng serve --configuration=production
        4. El nombre de la carpeta src/images debe coincidir con el de los dos scripts de compress.mjs y resize.mjs
        5. El directorio de scripts debe estar al mismo nivel del directorio src no adentro de el.
        6. Estos son los dos scripts:

        compress.mjs

        import imagemin from 'imagemin'; import pngquant from 'imagemin-pngquant'; import imageminWebp from 'imagemin-webp'; import webp from 'imagemin-webp'; const directory = "./src/assets/image/*.{webp, png}"; (async () => { const files = await imagemin([directory], { destination: "./src/assets/image/", plugins: [pngquant({ quality: [0.8, 0.8]}), imageminWebp({ quality: 80}), webp({ quality: 80})], }) console.log('Images optimized', files); })(); ```resize.mjs ```js import sharp from "sharp"; import * as fs from "fs"; const directory = "./src/assets/image"; fs.readdirSync(directory).forEach(async (file) => { try { const image = sharp(`${directory}/${file}`); const name = file.split(".")[0]; const { format } = await image.metadata(); if ( !name.includes ("small") && !name.includes("medium") && !name.includes ("large") && (format === "png" || format === "webp") ) { image .resize(450) // width .toFile(`${directory}/${name}-small.${format}`); image .resize(750) // width .toFile(`${directory}/${name}-medium.${format}`); image .resize(1800) // width .toFile(`${directory}/${name}-large.${format}`); } }catch(error){ console.log("Error: ", error); console.log(file); } }) ```7. Este es el ts del componente img ```js import { Component, Input, AfterContentInit } from '@angular/core'; interface Source { path: string; media: string; } @Component({ selector: 'app-img', templateUrl: './img.component.html', styleUrls: ['./img.component.scss'] }) export class ImgComponent implements AfterContentInit{ srcset: string = ''; media: string = ''; sources: Source[] = []; @Input() path: string = ''; @Input() alt: string = ''; ngAfterContentInit(): void { this.generateSizes(); } generateSizes(){ // Descomposición de nombre de imagen, path y extensión const splitPath = this.path.split('/'); const fullName = splitPath.pop(); const path = splitPath.join('/'); const splitName = fullName?.split('.') ?? []; const ext = splitName.pop(); const name = splitName.pop(); // Ruta de imagenes this.sources = [ { path: `${path}/${name}-large.webp`, media: '(min-width: 2000px)', }, { path: `${path}/${name}-medium.webp`, media: '(min-width: 640px)', }, { path: `${path}/${name}-small.webp`, media: '(min-width: 200px)', }, { path: `${path}/${name}-large.${ext}`, media: '(min-width: 2000px)', }, { path: `${path}/${name}-medium.${ext}`, media: '(min-width: 640px)', }, { path: `${path}/${name}-small.${ext}`, media: '(min-width: 200px)', }, ]; } } ```y este su html: ```js <picture> <source srcset="source.path" media="source.media" *ngFor="let source of sources" > <img [src]="path" alt="alt" loading="lazy" decoding="async"> </picture>
        Jorge Caloir

        Jorge Caloir

        student•
        hace 2 años

        no entiendo nada!

          Agustin Cammarota Muti

          Agustin Cammarota Muti

          student•
          hace 2 años

          Es bastante avanzado algunos cosas que se están tocando, performance, accesibilidad, CEO... Te recomiendo que lo dejes para el final de la ruta de aprendizaje