CursosEmpresasBlogLiveConfPrecios

Selector de Idioma en Next.js con Cookies y API Personalizada

Clase 7 de 12 • Curso de Next.js: Internacionalización de Aplicaciones Web con i18n

Contenido del curso

Introducción

  • 1
    Internacionalización Web con Next.js: Arquitectura y Prácticas Clave

    Internacionalización Web con Next.js: Arquitectura y Prácticas Clave

    09:27 min

Arquitectura

  • 2
    Arquitectura de Aplicaciones con Internacionalización en Next.js

    Arquitectura de Aplicaciones con Internacionalización en Next.js

    06:14 min
  • 3
    Internacionalización en NextJS: Configuración y Estrategias de Rutas

    Internacionalización en NextJS: Configuración y Estrategias de Rutas

    10:52 min

Rutas i18n

  • 4
    Implementación de Localización en Páginas Estáticas con Next.js y Contentful

    Implementación de Localización en Páginas Estáticas con Next.js y Contentful

    04:04 min
  • 5
    Internacionalización en Next.js: Gestión de Páginas Dinámicas y Locales

    Internacionalización en Next.js: Gestión de Páginas Dinámicas y Locales

    10:07 min

Experiencia de usuario

  • 6
    Internacionalización de Idiomas con Next.js y Cookies

    Internacionalización de Idiomas con Next.js y Cookies

    06:02 min
  • 7
    Selector de Idioma en Next.js con Cookies y API Personalizada

    Selector de Idioma en Next.js con Cookies y API Personalizada

    Viendo ahora

Arquitectura React

  • 8
    Internacionalización de Labels en Next.js con JSON

    Internacionalización de Labels en Next.js con JSON

    06:27 min
  • 9
    Internacionalización en React y Next.js: Estrategias y Soluciones

    Internacionalización en React y Next.js: Estrategias y Soluciones

    11:55 min
  • 10
    Internacionalización en React con Next.js y i18next

    Internacionalización en React con Next.js y i18next

    11:30 min

Próximos pasos

  • 11
    Retos de Internacionalización en Aplicaciones React

    Retos de Internacionalización en Aplicaciones React

    04:17 min
  • 12
    Internacionalización con Next.js y JavaScript Avanzado

    Internacionalización con Next.js y JavaScript Avanzado

    02:29 min
Tomar examen
Resumen

Git tag: 7-locales-nextjs Comando: git checkout -b dev 7-locales-nextjs

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
        Carlos Antonio Castillo Blas

        Carlos Antonio Castillo Blas

        student•
        hace 3 años

        Con js-cookie se puede grabar la cookie en el frontend y recargar la página.

        import Cookies from 'js-cookie'; const MyComponent = () => { const { locale } = useRouter(); const onChangeLanguage = () => { const newLocale = locale === 'en' ? 'es' : 'en'; Cookies.set('NEXT_LOCALE', newLocale, { path: '/' }); window.location.href = '/'; }; return <button onClick={onChangeLanguage}>es/en</button>; };
        BRANDON YESID ARRIETA GIRALDO

        BRANDON YESID ARRIETA GIRALDO

        student•
        hace 3 años

        que clase mas paila sinceramente

        Cesar González Caballero

        Cesar González Caballero

        student•
        hace 3 años

        Pues no funciona, copie el código, lo bajé directo, y no funciona manda a api/languaje en vez de como a el, algo hizo que no comparte y no funciona.

          Cristian Mauricio Cavanzo Arias

          Cristian Mauricio Cavanzo Arias

          student•
          hace 3 años

          Que no te funciona Cesar, es un error de consola o el codigo no funciona como deberia?

          Ulqernesh Karvenae

          Ulqernesh Karvenae

          student•
          hace 3 meses

          Instalaste la dependencia de cookie?

          npm i cookie@^0.4.1
        Roger David Alba Ortega

        Roger David Alba Ortega

        student•
        hace 3 años

        Buen dia, estoy trabajando en una app que se quiere aplicar la internacionalizacion, se trabaja el lenguaje "en" por defecto y el lenguaje "es" como opcional, estoy aplicando el codigo de la api/language me cambia cuando hago click, trabaja bien, pero cuando se selecciona el idioma ingles y sobre escribo el link asi "//localhost:3000/es" no me redirige al idioma que esta guardada en la cookie en cambio cuando selecciono el idioma "es" y reescribo el link asi "//localhost:3000" me lo cambia a este enlace "//localhost:3000/es". No entiendo porque funciona en el de espanol y no en el de ingles pueden ayudarme.

          Roger David Alba Ortega

          Roger David Alba Ortega

          student•
          hace 3 años

          este es el codigo que tengo

          import { serialize, CookieSerializeOptions } from "cookie" import { NextApiHandler, NextApiResponse } from "next" // Sadly, getting the locale info in API Routes is not officially supported. // It should match next.config::i18n.defaultLocale const DEFAULT_LOCALE = "en-US" // Learn more: https://nextjs.org/docs/advanced-features/i18n-routing#leveraging-the-next_locale-cookie const PREFERRED_LOCALE_COOKIE = "NEXT_LOCALE" function setCookie( res: NextApiResponse, name: string, value: unknown, options: CookieSerializeOptions = {expires: new Date(Date.now() + 60*60*24*2 ) , maxAge: 10} ) { const stringValue = typeof value === "object" ? `j:${ JSON.stringify(value)}` : String(value) res.setHeader("Set-Cookie", serialize(name, String(stringValue), options)) } const language: NextApiHandler = (request, response) => { if (request.method === "GET") { const preferredLocale = request.cookies[PREFERRED_LOCALE_COOKIE] return response.status(200).json({ preferredLocale, defaultLocale: DEFAULT_LOCALE, }) } if (request.method === "POST") { const newPreferredLocale = request.body.preferredLocale as | string | undefined // For this page, we don't care setting an invalid value. // worst case: the value is ignored and Next.js defaults to defaultLocale. Not critical. setCookie(response, PREFERRED_LOCALE_COOKIE, newPreferredLocale, { // Heads-up: the NEXT_LOCALE must be set to the `/` path path: "/", }) // 307 (temporary) redirect to homepage response.redirect("/") return response.end() } // Not other supported method return response.status(405).end() } export default language
          Roger David Alba Ortega

          Roger David Alba Ortega

          student•
          hace 3 años
          /** * @type {import('next').NextConfig} */ const nextConfig = { reactStrictMode: true, webpack(config) { const modifiedConfig = { ...config, resolve: { ...config.resolve, fallback: { ...config.resolve.fallback, fs: false, }, }, } return modifiedConfig }, i18n: { locales: ["en-US","es"], defaultLocale: "en-US", } } module.exports = nextConfig```
        Israel Hernández Galicia

        Israel Hernández Galicia

        student•
        hace 2 años

        Al igual tendran que instalar esta dependencia y forzarla, no deberia ocasionar conflictos si hacen un npm audit:

        npm install --save-dev @types/cookie --force

        Israel Hernández Galicia

        Israel Hernández Galicia

        student•
        hace 2 años

        Para instalar la dependencia cookie en 2024, tendran que usar este flag, si no, no deja instalar por los conflictos con las otras dependencias:

        npm install cookie --legacy-peer-deps

        Luis Felipe Silgado Cortázar

        Luis Felipe Silgado Cortázar

        student•
        hace 2 años

        ¿Cómo dibujar un rostro hiper realista?

        1. dibuja un círculo.
        2. Dibuja las líneas del rostro.
        3. Agrega detalles.

        ¡Y en 3 simples pasos tienes tu rostro hiper realista!

          Luis Felipe Silgado Cortázar

          Luis Felipe Silgado Cortázar

          student•
          hace 2 años
          2023-08-29_18h40_05.png