CursosEmpresasBlogLiveConfPrecios

Caché de requests

Clase 11 de 20 • Curso de Progressive Web Apps con Angular 8

Clase anteriorSiguiente clase

Contenido del curso

Apropiar el concepto de PWA

  • 1
    Cómo crearás una PWA con Angular

    Cómo crearás una PWA con Angular

    00:36 min
  • 2
    ¿Qué son las PWA?

    ¿Qué son las PWA?

    03:27 min
  • 3
    Características de una PWA

    Características de una PWA

    05:10 min
  • 4
    PWA vs Híbrido vs Nativo

    PWA vs Híbrido vs Nativo

    04:05 min
  • 5
    Los Services Workers

    Los Services Workers

    03:46 min
  • 6
    Proyecto del curso: Platzi Store

    Proyecto del curso: Platzi Store

    02:01 min

Entender PWA en Angular

  • 7
    Generando la primer PWA

    Generando la primer PWA

    13:55 min
  • 8
    Caché local y pruebas offline

    Caché local y pruebas offline

    09:02 min
  • 9
    Pruebas con Lighthouse

    Pruebas con Lighthouse

    07:49 min
  • 10
    Caché de assets

    Caché de assets

    05:20 min
  • 11
    Caché de requests

    Caché de requests

    Viendo ahora

Construir una PWA luciendo como nativa

  • 12
    Poniendo tu app en el Homescreen

    Poniendo tu app en el Homescreen

    07:24 min
  • 13
    Crear botón de instalación automática

    Crear botón de instalación automática

    17:02 min
  • 14
    Probar funcionalidad del botón de instalación

    Probar funcionalidad del botón de instalación

    08:11 min
  • 15
    Enviando actualizaciones

    Enviando actualizaciones

    12:44 min
  • 16
    Implementando flujo de notificaciones

    Implementando flujo de notificaciones

    13:22 min
  • 17
    Gestionando notificaciones

    Gestionando notificaciones

    12:14 min
  • 18
    Implementación y recomendaciones para IOS

    Implementación y recomendaciones para IOS

    09:23 min

Integrar continuamente

  • 19
    Aplicando Lighthouse Bot a tu proceso de integración continua

    Aplicando Lighthouse Bot a tu proceso de integración continua

    04:58 min
  • 20
    Conclusiones

    Conclusiones

    00:33 min
  • Tomar el examen del curso
    • Jose Luis Rosado Cardenas

      Jose Luis Rosado Cardenas

      student•
      hace 5 años

      CORRECCION definió bien maxSize al principio pero al explicarlo como que confunde, ya que efectivamente indica la cantidad de peticiones a almacenar, es decir, si ponemos 3, solo 3 request se van a cachear, segun la politica de angular, es decir si se queda offline, y ya habías navegado antes, solo 3 request son obtenidos de la cache del service worker, y los demás no habría respuesta

        Rodrigo Rodriguez

        Rodrigo Rodriguez

        student•
        hace 4 años

        Vale la aclaracion, gracias!

      Formacion1 Formacion1

      Formacion1 Formacion1

      student•
      hace 6 años

      Configuración de cache: "dataGroups": [ { "name": "api", "urls": [ "https://platzi-store.herokuapp.com/**" ], "cacheConfig": { "maxSize": 3, "maxAge": "5m", "strategy": "performance", "timeout": "2s" } } ]

        Luis Abdel Rangel Castro

        Luis Abdel Rangel Castro

        student•
        hace 5 años
        "dataGroups": [ { "name": "api", "urls": ["https://platzi-store.herokuapp.com/**"], "cacheConfig": { "maxSize": 3, "maxAge": "5m", "strategy": "performance", "timeout": "3s" } } ]
      Carlos Andres Carvajal

      Carlos Andres Carvajal

      student•
      hace 5 años

      Strategy: perfomance: saca del caché la información primero, si no hay consulta internet freshness: primero va a internet, si es una red lenta va a caché.

      Arturo Munoz Cantor

      Arturo Munoz Cantor

      student•
      hace 5 años

      "maxAge": "5m", => d-days - h-hour - m-min - s -sec - u-msec

      Diosnel Enrique Velázquez Escobar

      Diosnel Enrique Velázquez Escobar

      student•
      hace 6 años
      • perfomance: saca del cache primero
      • freshness: pide al servidor primero
      Michael Camargo

      Michael Camargo

      student•
      hace 3 años

      tengo este error sin conexion

      ngsw-worker.js:851 Uncaught (in promise) TypeError: Failed to fetch at DataGroup.safeFetch (ngsw-worker.js:851:27) at DataGroup.handleFetch (ngsw-worker.js:708:23) at async AppVersion.handleFetch (ngsw-worker.js:924:20) at async Driver.handleFetch (ngsw-worker.js:1432:19)

        Juan Luna

        Juan Luna

        student•
        hace 3 años

        yo también

      Ezequiel Saldaña

      Ezequiel Saldaña

      student•
      hace 6 años

      A veces dice que performance toma de la red primero y a veces dice que primero toma de caché. Lo mismo pasa cuando habla de freshness. Se vuelve todo confuso.

        Anthony Hurtado

        Anthony Hurtado

        student•
        hace 5 años

        Me parece que el tema de strategy es:

        • perfomance: saca del cache primero la información
        • freshness: pide al servidor primero la información
      Brayan Alexis Valdes Gallego

      Brayan Alexis Valdes Gallego

      student•
      hace 6 años

      También es admisible pasar como dataGroups las respuestas que da las apis de google en cuanto a letras o iconos? tipo https://fonts.googleapis.com/** ?

      Luis Abdel Rangel Castro

      Luis Abdel Rangel Castro

      student•
      hace 5 años

      Que bonito es lo bonito!!!

      DANIEL ARIAS VÁZQUEZ

      DANIEL ARIAS VÁZQUEZ

      student•
      hace 5 años

      necesito ayuda por favor ya no pude instalar correctamente la documentación para firebase, gracias.

      Gerardo Manuel Reyes Fernández

      Gerardo Manuel Reyes Fernández

      student•
      hace 6 años

      El maxSize no lo veo como intentos, es el numero de request almacenadas, como lo entiendo es, puedes hacer 3 peticiones, cambiando algún parámetro y solo guarda esas 3 después va liberando espacio en memoria.

      Juan Luna

      Juan Luna

      student•
      hace 3 años

      Buenas tardes Nicolás, tengo problemas para hacer funcionar la app, no se si es que la url de la API, no funciona o es un tema de permisos, de firebase, el caso es que mirando el archivo 'firebase-messaging-sw.js', veo que está configurado para la app de platzi y no para la mía, ¿cómo debo hacer esta configuración?, ¿quizás hayan archivos en vuestro github que no se deberían haber subido, para generarlos desde firebase init?

      Bueno el caso es que lo estoy configurando, poniendo los datos sacados de firebase de mi proyecto alí, pero no encuentro dos cosas, la apiKey y el appId, y el storageBucket, me lo he inventado ¿Alguna sugerencia, gracias?

      Un saludo y enhorabuena por tus cursos.

      Jose Luis Rosado Cardenas

      Jose Luis Rosado Cardenas

      student•
      hace 5 años

      ¿Puedo usar alguna variable del archivo environment.ts en el archivo ngsw-config.json, para definir las urls??

        Johan Rujano

        Johan Rujano

        student•
        hace 5 años

        Tengo la misma duda lograste; hacerlo?

        Jose Luis Rosado Cardenas

        Jose Luis Rosado Cardenas

        student•
        hace 5 años

        no, sigo con la duda

      Rafael

      Rafael

      student•
      hace 3 años

      ¿como hago para guardar en el navegador un formulario y que se mande a guardar cuando tenga conexion a internet?

      Michael Camargo

      Michael Camargo

      student•
      hace 3 años

      tango este error

      ngsw-worker.js:851 Uncaught (in promise) TypeError: Failed to fetch at DataGroup.safeFetch (ngsw-worker.js:851:27) at DataGroup.handleFetch (ngsw-worker.js:708:23) at async AppVersion.handleFetch (ngsw-worker.js:924:20) at async Driver.handleFetch (ngsw-worker.js:1432:19)

      Mariela de Jesus Rivas Hernandez

      Mariela de Jesus Rivas Hernandez

      student•
      hace 3 años

      Tengo un error, al parecer no me reconoce el services worker pero no entiendo el porqué, si alguien sabe que es lo que podría estar mal.

      Captura de Pantalla 2022-06-14 a la(s) 10.00.34.png

      esto es lo que tengo dentro del archivo enviroments.ts

      Captura de Pantalla 2022-06-14 a la(s) 10.02.29.png
      Rafael

      Rafael

      student•
      hace 4 años

      si tengo un dominio con varios subdominios pero el final de la url es el mismo entonces lo puedo obtener desde el environment o tengo que agregar uno por uno en el datagroup

        Xavier Medina Veintimilla

        Xavier Medina Veintimilla

        student•
        hace 4 años

        ¡Hola! :D

        ¿Cuál es el problema que tienes?, ¿en qué te puedo ayudar?

        Nunca pares de aprender 💚

      Andres Gallardo

      Andres Gallardo

      student•
      hace 6 años

      El cache es por sesion de navegador ? O como funciona ?

        Nicolas Molina

        Nicolas Molina

        teacher•
        hace 6 años

        Hola!

        Este cache queda guardado al navegador directamente y no queda asociando a la sesión del usuario en la pagina.

        Aunque si manejas la sincronización dentro de Google Chrome con tu Gmail esto si se mantiene por cada usuario.

      Fernando Garcia

      Fernando Garcia

      student•
      hace 5 años

      Tiempo de vida de cache: nombre: maxAge formato: d (días) , h (horas), m (minutos) ej: 1d (este cache durará un días)

      Fernando Garcia

      Fernando Garcia

      student•
      hace 5 años

      assetsGroups : para archivos estaticos dataGroups : para requests a servidores

    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