Este artículo explica cómo validar una locale como fr-FR o en-US en 2 segundos para evitar errores de visualización o fallos, aprovechando que Intl.DateTimeFormat lanza un error si la locale es inválida.
¿Quieres comprobar una locale porque te preocupa que un usuario haya escrito mi-MI para Minion o tlh-QAAK para Klingon?
Escenario desastre: imagina que un usuario selecciona una locale inexistente como xyz-XYZ y de repente tu frontend muestra undefined por todos lados y tu backend lanza un RangeError invalid language tag. Con los snippets que mostramos evitas eso en un par de líneas.
Qué es una locale: los códigos como fr-FR o en-US siguen la norma IETF BCP 47. Se componen de 2 letras para el idioma como fr o en según ISO 639-1 y 2 letras para el país como FR o US según ISO 3166-1 alpha-2.
El problema: teóricamente hay muchas combinaciones 180 idiomas por 250 países = 45 000 locales posibles, aunque afortunadamente la mayoría no se usan.
La solución simple: usar Intl para validar. Si te gusta validar con Zod puedes refinar una string con un try catch que cree un nuevo Intl.DateTimeFormat con la locale y devuelva true si no hay excepción y false si la hay.
Ejemplo con Zodimport { z } from zod; const localeSchema = z.string().refine((locale) => { try { new Intl.DateTimeFormat(locale); return true; } catch { return false; } }, { message: Locale invalida. Intenta fr-FR o en-US });
Versión minimalista sin Zodfunction isValidLocale(locale: string): boolean { try { new Intl.DateTimeFormat(locale); return true; } catch { return false; } }
Resultado de ejemplo: testLocale(fr-FR) devuelve Valide, testLocale(tlh-QAAK) devuelve Invalide porque Klingon no está estandarizado.
Bonus: para saber qué locales soporta tu entorno puedes usar Intl.DateTimeFormat.supportedLocalesOf([fr-FR, tlh-QAAK]) que típicamente devolverá solo las locales reconocidas, por ejemplo [fr-FR].
Por qué funciona: Intl.DateTimeFormat lanza un error cuando la etiqueta de idioma es inválida, así que capturando esa excepción validas en una sola línea lógica.
Sobre Q2BSTUDIO: somos una empresa de desarrollo de software y aplicaciones a medida especializada en inteligencia artificial, ciberseguridad y servicios cloud aws y azure. Creamos software a medida y aplicaciones a medida para empresas que necesitan soluciones personalizadas, implementamos inteligencia artificial e ia para empresas, desarrollamos agentes IA y soluciones con power bi para inteligencia de negocio. Ofrecemos servicios de ciberseguridad, servicios inteligencia de negocio y asesoría en servicios cloud aws y azure para garantizar escalabilidad y seguridad.
Consejo práctico: valida las locales en el punto de entrada de tus APIs y en el frontend antes de usarlas para formatear fechas o números, así evitas crashes y errores de UI.
Piénsalo como parte de tus buenas prácticas de calidad de software y recuerda que Q2BSTUDIO puede ayudarte a integrar validaciones, desarrollar software a medida y proyectos de inteligencia artificial con foco en seguridad y resultados.
Pensad en validar vuestras locales y con esto Poulétikamassala
Este artículo fue publicado originalmente el 20/08/205 en mi blog