CursosEmpresasBlogLiveConfPrecios

Agregando un loader

Clase 20 de 23 • Curso de Next.js 2018

Clase anteriorSiguiente clase

Contenido del curso

Introducción a Next.JS
  • 1

    ¿Dónde aprender Next.js actualizado?

    00:14
  • 2
    ¿Qué es Next.JS?

    ¿Qué es Next.JS?

    01:41
  • 3
    Creando nuestra primera página

    Creando nuestra primera página

    07:44
  • 4
    Styled JSX

    Styled JSX

    09:54
Server Side Rendering
  • 5
    Aprende qué es Server Side Rendering

    Aprende qué es Server Side Rendering

    04:15
  • 6
    Intro a getInitialProps

    Intro a getInitialProps

    14:44
  • 7
    Utilizando el componente Link

    Utilizando el componente Link

    08:01
  • 8
    Recibiendo Parámetros

    Recibiendo Parámetros

    13:20
  • 9
    Performance de Get Initial Props

    Performance de Get Initial Props

    04:39
  • 10
    Vista de Podcasts

    Vista de Podcasts

    02:07
Componentes Reutilizables
  • 11
    Creando componentes en React

    Creando componentes en React

    15:16
  • 12
    Reorganizar la vista de podcasts

    Reorganizar la vista de podcasts

    03:03
Navegación Avanzada
  • 13
    Gestionando Errores

    Gestionando Errores

    14:06
  • 14
    Personalizando errores

    Personalizando errores

    10:21
  • 15
    ¿Cómo diseñar URLs?

    ¿Cómo diseñar URLs?

    03:34
  • 16
    Configurando Next Routes

    Configurando Next Routes

    11:26
  • 17
    Implementando Next Routes

    Implementando Next Routes

    08:04
  • 18
    Vistas Híbridas

    Vistas Híbridas

    12:56
  • 19
    Implementar el Modal

    Implementar el Modal

    06:24
  • 20
    Agregando un loader

    Agregando un loader

    03:44
Publicando nuestra app
  • 21
    Mejores prácticas en Github

    Mejores prácticas en Github

    04:33
  • 22
    Publicar la app con now

    Publicar la app con now

    02:39
  • 23
    Conclusiones del curso

    Conclusiones del curso

    01:07
    Sergio Alejandro Trejo Cuxim

    Sergio Alejandro Trejo Cuxim

    student•
    hace 6 años

    Esta es la versión actualizada para Next.js V9

    Router.events.on('routeChangeStart', () => NProgress.start() ); Router.events.on('routeChangeComplete', () => NProgress.done() ); Router.events.on('routeChangeError', () => NProgress.done() );
      Noel Zenon Callapiña Angles

      Noel Zenon Callapiña Angles

      student•
      hace 6 años

      Muchas Gracias!! tu tip me ayudó!!!

    Sergio Toshio Minei

    Sergio Toshio Minei

    student•
    hace 7 años

    Loaders

    Se va a usar nprogress para mostrar un loader al cargar las páginas.

    $ npm add nprogress

    Para usarlo, se debe agregar las siguientes líneas de código al inicio del componente princioan o Layout:

    import NProgress from 'nprogress'; import Router from 'next/router'; Router.onRouteChangeStart = (url) => { NProgress.start() } Router.onRouteChangeComplete = () => NProgress.done() Router.onRouteChangeError = () => NProgress.done()

    Además se debe de agregar la hoja de estilos de nprogress a los estilos globales del proyecto.

    Pueden ver el resumen completo del curso aquí.
    Pueden ver mi lista de resúmenes aquí.

    Ivan Trujillo

    Ivan Trujillo

    student•
    hace 6 años

    Custom Hook con el loading del curso:

    import * as React from "react"; import { useRouter } from "next/router"; import NProgress from "nprogress"; export const useLoading = () => { const router = useRouter(); React.useEffect(() => { const handleStart = () => NProgress.start(); const handleComplete = () => NProgress.done(); router.events.on("routeChangeStart", handleStart); router.events.on("routeChangeComplete", handleComplete); router.events.on("routeChangeError", handleComplete); return () => { router.events.off("routeChangeStart", handleStart); router.events.off("routeChangeComplete", handleComplete); router.events.off("routeChangeError", handleComplete); }; }); };

    Luego lo importan en Layout y lo ejecutan:

    import Link from "next/link"; import Head from "next/head"; import { useLoading } from "../hooks/useLoading"; export const Layout = ({ children, title, }: { children: React.ReactChild | React.ReactChild[]; title: string; }) => { useLoading(); return ( <div className=" flex flex-col h-screen w-screen "> <Head> <title>{title}</title> <meta name="viewport" content="width=device-width, initial-scale=1" ></meta> </Head> <header className="bg-purple-900 p-4 text-white text-center"> <Link href="/"> <a>Podcasts</a> </Link> </header> <div className="flex flex-col flex-1 items-center overflow-auto"> {children} </div> </div> ); };
    Raúl F. Bautista Gómez

    Raúl F. Bautista Gómez

    student•
    hace 6 años

    Aquí encontraran el CSS del ejemplo

      Fabián andres Pedraza Borhorquez

      Fabián andres Pedraza Borhorquez

      student•
      hace 5 años

      Gracias

    William Velázquez

    William Velázquez

    student•
    hace 7 años

    Hoja de estilos de nprogress 😃
    nprogress.css

    William Velázquez

    William Velázquez

    student•
    hace 7 años

    Ejemplo with-loading the next.js
    https://github.com/zeit/next.js/tree/canary/examples/with-loading
    😄

    William Velázquez

    William Velázquez

    student•
    hace 7 años

    Enlace a NProgress.js
    http://ricostacruz.com/nprogress/
    😃

    Pablo Tabares Hernandez

    Pablo Tabares Hernandez

    student•
    hace 6 años

    Router.onRouteChangeStart = (url) => { NProgress.start() } Router.onRouteChangeComplete = () => NProgress.done() Router.onRouteChangeError = () => NProgress.done()

    Diego Guevara

    Diego Guevara

    student•
    hace 7 años

    Hola, como se debe importar en Nextjs una CSS desde un archivo externo?

      Diego Forero

      Diego Forero

      Team Platzi•
      hace 7 años

      Puedes usar este plugin https://github.com/zeit/next-plugins/tree/master/packages/next-css

      Diego Guevara

      Diego Guevara

      student•
      hace 7 años

      Gracias!

    Carlos Arboleda

    Carlos Arboleda

    student•
    hace 6 años

    Por si quieren crear su propio Loading component…

    import { useRouter } from 'next/router'; const Loading = () => { const router = useRouter(); const [ loading, setLoading ] = React.useState(''); React.useEffect(() => { const handleStart = (url) => url !== router.pathname && setLoading(true); const handleComplete = (url) => url !== router.pathname && setLoading(false); router.events.on('routeChangeStart', handleStart); router.events.on('routeChangeComplete', handleComplete); router.events.on('routeChangeError', handleComplete); return () => { router.events.off('routeChangeStart', handleStart); router.events.off('routeChangeComplete', handleComplete); router.events.off('routeChangeError', handleComplete); }; }); return loading && <div>Loading...</div>; }; export default Loading;

    Despues solo importenlo en Layout 🙃

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