Haz tu pregunta y obtén un resumen del documento referenciando esta página y el proveedor AI de tu elección
Este documento está desactualizado, la versión base se actualizó el 20 de enero de 2026.
Ir a la documentación en inglésHistorial de versiones
- "Añadidos formateadores para Vue"v5.8.020/8/2025
- "Añadida documentación de formateadores"v5.8.018/8/2025
- "Añadido formateadores de vue"v5.8.020/8/2025
- "Añadida documentación de formateadores"v5.8.018/8/2025
- "Añadida documentación del formateador de listas"v5.8.020/8/2025
- "Añadidas utilidades Intl adicionales (DisplayNames, Collator, PluralRules)"v5.8.020/8/2025
- "Añadidas utilidades de configuración regional (getLocaleName, getLocaleLang, getLocaleFromPath, etc.)"v5.8.020/8/2025
- "Añadidas utilidades para manejo de contenido (getContent, getTranslation, getIntlayer, etc.)"v5.8.020/8/2025
El contenido de esta página ha sido traducido con una IA.
Ver la última versión del contenido original en inglésSi tienes una idea para mejorar esta documentación, no dudes en contribuir enviando una pull request en GitHub.
Enlace de GitHub a la documentaciónCopiar el Markdown del documento a la portapapeles
Formateadores de Intlayer
Resumen
Intlayer proporciona un conjunto de helpers ligeros construidos sobre las APIs nativas de Intl, además de un wrapper Intl en caché para evitar construir repetidamente formateadores pesados. Estas utilidades son completamente conscientes del locale y pueden usarse desde el paquete principal intlayer.
Importar
Si usas React, también hay hooks disponibles; consulta react-intlayer/format.
Intl en caché
El Intl exportado es un wrapper ligero y en caché alrededor del Intl global. Memoiza instancias de NumberFormat, DateTimeFormat, RelativeTimeFormat, ListFormat, DisplayNames, Collator y PluralRules, lo que evita reconstruir repetidamente el mismo formateador.
Debido a que la construcción de formateadores es relativamente costosa, esta caché mejora el rendimiento sin cambiar el comportamiento. El wrapper expone la misma API que el Intl nativo, por lo que el uso es idéntico.
- La caché es por proceso y transparente para los llamadores.
Si Intl.DisplayNames no está disponible en el entorno, se imprime una única advertencia solo para desarrolladores (considera usar un polyfill).
Ejemplos:
Utilidades adicionales de Intl
Más allá de los ayudantes para formateadores, también puedes usar directamente el wrapper cacheado de Intl para otras funcionalidades de Intl:
Intl.DisplayNames
Para nombres localizados de idiomas, regiones, monedas y escrituras:
Intl.Collator
Para la comparación y ordenación de cadenas conscientes del locale:
Intl.PluralRules
Para determinar las formas plurales en diferentes locales:
Utilidades de Locale
getLocaleName(displayLocale, targetLocale?)
Obtiene el nombre localizado de un locale en otro locale:
- displayLocale: El locale para el cual obtener el nombre
- targetLocale: El locale en el que se mostrará el nombre (por defecto es displayLocale)
getLocaleLang(locale?)
Extrae el código de idioma de una cadena de locale:
- locale: El locale del cual extraer el idioma (por defecto es el locale actual)
getLocaleFromPath(inputUrl)
Extrae el segmento de locale de una URL o ruta:
- inputUrl: La cadena completa de URL o ruta a procesar
- returns: El locale detectado o el locale predeterminado si no se encuentra ningún locale
getPathWithoutLocale(inputUrl, locales?)
Elimina el segmento de locale de una URL o ruta:
- inputUrl: La cadena completa de URL o ruta a procesar
- locales: Matriz opcional de locales soportados (por defecto, los locales configurados)
- returns: La URL sin el segmento de locale
getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)
Genera una URL localizada para el locale actual:
- url: La URL original para localizar
- currentLocale: El locale actual
- locales: Matriz opcional de locales soportados (por defecto, los locales configurados)
- defaultLocale: Locale predeterminado opcional (por defecto, el locale predeterminado configurado)
- prefixDefault: Indica si se debe prefijar el locale predeterminado (por defecto, el valor configurado)
getHTMLTextDir(locale?)
Devuelve la dirección del texto para un locale:
- locale: El locale para obtener la dirección del texto (por defecto, el locale actual)
- returns:
"ltr","rtl"o"auto"
Utilidades para el Manejo de Contenido
getContent(node, nodeProps, locale?)
Transforma un nodo de contenido con todos los plugins disponibles (traducción, enumeración, inserción, etc.):
- node: El nodo de contenido a transformar
- nodeProps: Propiedades para el contexto de transformación
- locale: Locale opcional (por defecto, el locale predeterminado configurado)
getTranslation(languageContent, locale?, fallback?)
Extrae contenido para un locale específico de un objeto de contenido multilingüe:
- languageContent: Objeto que mapea locales a contenido
- locale: Locale objetivo (por defecto el locale predeterminado configurado)
- fallback: Indica si se debe usar el locale predeterminado como respaldo (por defecto es true)
getIntlayer(dictionaryKey, locale?, plugins?)
Recupera y transforma contenido de un diccionario por clave:
- dictionaryKey: La clave del diccionario a recuperar
- locale: Locale opcional (por defecto es el locale predeterminado configurado)
- plugins: Array opcional de plugins personalizados para transformación
getIntlayerAsync(dictionaryKey, locale?, plugins?)
Recupera contenido de un diccionario remoto de forma asíncrona:
- dictionaryKey: La clave del diccionario a recuperar
- locale: Locale opcional (por defecto es el locale predeterminado configurado)
- plugins: Array opcional de plugins personalizados para transformación
Formateadores
Todos los helpers a continuación son exportados desde intlayer.
number(value, options?)
Formatea un valor numérico utilizando agrupación y decimales sensibles al locale.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Ejemplos:
percentage(value, options?)
Formatea un número como una cadena de porcentaje.
Comportamiento: los valores mayores que 1 se interpretan como porcentajes enteros y se normalizan (por ejemplo, 25 → 25%, 0.25 → 25%).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Ejemplos:
currency(value, options?)
Formatea un valor como moneda localizada. Por defecto es USD con dos dígitos decimales.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- Campos comunes:
currency(por ejemplo,"EUR"),currencyDisplay("symbol" | "code" | "name")
- Campos comunes:
Ejemplos:
date(date, optionsOrPreset?)
Formatea un valor de fecha/hora con Intl.DateTimeFormat.
- date:
Date | string | number - optionsOrPreset:
Intl.DateTimeFormatOptions & { locale?: LocalesValues }o uno de los preajustes:- Preajustes:
"short" | "long" | "dateOnly" | "timeOnly" | "full"
- Preajustes:
Ejemplos:
relativeTime(from, to = new Date(), options?)
Formatea el tiempo relativo entre dos instantes con Intl.RelativeTimeFormat.
- Pasa "now" como primer argumento y el objetivo como segundo para obtener una frase natural.
- from:
Date | string | number - to:
Date | string | number(por defectonew Date()) - options:
{ locale?: LocalesValues; unit?: Intl.RelativeTimeFormatUnit; numeric?: Intl.RelativeTimeFormatNumeric; style?: Intl.RelativeTimeFormatStyle }- El valor predeterminado de
unites"second".
- El valor predeterminado de
Ejemplos:
units(value, options?)
Formatea un valor numérico como una cadena de unidad localizada usando Intl.NumberFormat con style: 'unit'.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- Campos comunes:
unit(por ejemplo,"kilometer","byte"),unitDisplay("short" | "narrow" | "long") - Valores predeterminados:
unit: 'day',unitDisplay: 'short',useGrouping: false
- Campos comunes:
Ejemplos:
compact(value, options?)
Formatea un número usando notación compacta (por ejemplo, 1.2K, 1M).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }(usa internamentenotation: 'compact')
Ejemplos:
list(values, options?)
Formatea un arreglo de valores en una cadena de lista localizada usando Intl.ListFormat.
- values:
(string | number)[] - options:
Intl.ListFormatOptions & { locale?: LocalesValues }- Campos comunes:
type("conjunction" | "disjunction" | "unit"),style("long" | "short" | "narrow") - Valores por defecto:
type: 'conjunction',style: 'long'
- Campos comunes:
Ejemplos:
Notas
- Todos los ayudantes aceptan entradas de tipo
string; internamente se convierten a números o fechas. - El locale por defecto es el configurado en
internationalization.defaultLocalesi no se proporciona. - Estas utilidades son envoltorios ligeros; para un formateo avanzado, pase las opciones estándar de
Intl.
Puntos de entrada y re-exportaciones (@index.ts)
Los formateadores residen en el paquete core y se re-exportan desde paquetes de nivel superior para mantener las importaciones ergonómicas en diferentes entornos de ejecución:
Ejemplos:
React
Componentes cliente:
Componentes del servidor (o tiempo de ejecución del servidor React):
Estos hooks considerarán la configuración regional desde elIntlayerProvideroIntlayerServerProvider
Vue
Componentes cliente:
Esos composables considerarán la configuración regional del IntlayerProvider inyectado.