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ésIf you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
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
Copiar el código al portapapeles
import { Intl, number, percentage, currency, date, relativeTime, units, compact, list, getLocaleName, getLocaleLang, getLocaleFromPath, getPathWithoutLocale, getLocalizedUrl, getHTMLTextDir, getContent, getTranslation, getIntlayer, getIntlayerAsync,} from "intlayer";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:
Copiar el código al portapapeles
import { Intl } from "intlayer";// Formateo de númerosconst numberFormat = new Intl.NumberFormat("en-GB", { style: "currency", currency: "GBP",});numberFormat.format(1234.5); // "£1,234.50"// Nombres para idiomas, regiones, etc.const displayNames = new Intl.DisplayNames("fr", { type: "language" });displayNames.of("en"); // "anglais"// Ordenación para clasificaciónconst collator = new Intl.Collator("fr", { sensitivity: "base" });collator.compare("é", "e"); // 0 (igual)// Reglas de pluralizaciónconst pluralRules = new Intl.PluralRules("fr");pluralRules.select(1); // "one"pluralRules.select(2); // "other"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:
Copiar el código al portapapeles
import { Intl } from "intlayer";const languageNames = new Intl.DisplayNames("en", { type: "language" });languageNames.of("fr"); // "Francés"const regionNames = new Intl.DisplayNames("fr", { type: "region" });regionNames.of("US"); // "Estados Unidos"Intl.Collator
Para la comparación y ordenación de cadenas conscientes del locale:
Copiar el código al portapapeles
import { Intl } from "intlayer";const collator = new Intl.Collator("de", { sensitivity: "base", numeric: true,});const words = ["äpfel", "zebra", "100", "20"];words.sort(collator.compare); // ["20", "100", "äpfel", "zebra"]Intl.PluralRules
Para determinar las formas plurales en diferentes locales:
Copiar el código al portapapeles
import { Intl } from "intlayer";const pluralRules = new Intl.PluralRules("ar");pluralRules.select(0); // "zero"pluralRules.select(1); // "one"pluralRules.select(2); // "two"pluralRules.select(3); // "few"pluralRules.select(11); // "many"Utilidades de Locale
getLocaleName(displayLocale, targetLocale?)
Obtiene el nombre localizado de un locale en otro locale:
Copiar el código al portapapeles
import { getLocaleName } from "intlayer";getLocaleName("fr", "en"); // "French"getLocaleName("en", "fr"); // "anglais"getLocaleName("de", "es"); // "alemán"- 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:
Copiar el código al portapapeles
import { getLocaleLang } from "intlayer";getLocaleLang("en-US"); // "en"getLocaleLang("fr-CA"); // "fr"getLocaleLang("de"); // "de"- 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:
Copiar el código al portapapeles
import { getLocaleFromPath } from "intlayer";getLocaleFromPath("/en/dashboard"); // "en"getLocaleFromPath("/fr/dashboard"); // "fr"getLocaleFromPath("/dashboard"); // "en" (locale predeterminado)getLocaleFromPath("https://example.com/es/about"); // "es"- 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:
Copiar el código al portapapeles
import { getPathWithoutLocale } from "intlayer";getPathWithoutLocale("/en/dashboard"); // "/dashboard"getPathWithoutLocale("/fr/dashboard"); // "/dashboard"getPathWithoutLocale("https://example.com/en/about"); // "https://example.com/about"- 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:
Copiar el código al portapapeles
import { getLocalizedUrl } from "intlayer";getLocalizedUrl("/about", "fr", ["en", "fr"], "en", false); // "/fr/about"getLocalizedUrl("/about", "en", ["en", "fr"], "en", false); // "/about"getLocalizedUrl("https://example.com/about", "fr", ["en", "fr"], "en", true); // "https://example.com/fr/about"- 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:
Copiar el código al portapapeles
import { getHTMLTextDir } from "intlayer";getHTMLTextDir("en-US"); // "ltr"getHTMLTextDir("ar"); // "rtl"getHTMLTextDir("he"); // "rtl"- 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.):
Copiar el código al portapapeles
import { getContent } from "intlayer";const content = getContent( contentNode, { dictionaryKey: "common", dictionaryPath: "/path/to/dict" }, "fr");- 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:
Copiar el código al portapapeles
import { getTranslation } from "intlayer";const content = getTranslation( { en: "Hello", fr: "Bonjour", de: "Hallo", }, "fr", true); // "Bonjour"- 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:
Copiar el código al portapapeles
import { getIntlayer } from "intlayer";const content = getIntlayer("common", "fr");const nestedContent = getIntlayer("common", "fr", customPlugins);- 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:
Copiar el código al portapapeles
import { getIntlayerAsync } from "intlayer";const content = await getIntlayerAsync("common", "fr");- 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:
Copiar el código al portapapeles
import { number } from "intlayer";number(123456.789); // "123,456.789" (en en-US)number("1000000", { locale: "fr" }); // "1 000 000"number(1234.5, { minimumFractionDigits: 2 }); // "1,234.50"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:
Copiar el código al portapapeles
import { percentage } from "intlayer";percentage(0.25); // "25%"percentage(25); // "25%"percentage(0.237, { minimumFractionDigits: 1 }); // "23.7%"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:
Copiar el código al portapapeles
import { currency } from "intlayer";currency(1234.5, { currency: "EUR" }); // "€1,234.50"currency("5000", { locale: "fr", currency: "CAD", currencyDisplay: "code" }); // "5 000,00 CAD"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:
Copiar el código al portapapeles
import { date } from "intlayer";date(new Date(), "short"); // p. ej., "08/02/25, 14:30"date("2025-08-02T14:30:00Z", { locale: "fr", month: "long", day: "numeric" }); // "2 août"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:
Copiar el código al portapapeles
import { relativeTime } from "intlayer";const now = new Date();const in3Days = new Date(now.getTime() + 3 * 864e5);relativeTime(now, in3Days, { unit: "day" }); // "en 3 días"const twoHoursAgo = new Date(now.getTime() - 2 * 3600e3);relativeTime(now, twoHoursAgo, { unit: "hour", numeric: "auto" }); // "hace 2 horas"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:
Copiar el código al portapapeles
import { units } from "intlayer";units(5, { unit: "kilometer", unitDisplay: "long", locale: "en-GB" }); // "5 kilometers"units(1024, { unit: "byte", unitDisplay: "narrow" }); // "1,024B" (dependiente del locale)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:
Copiar el código al portapapeles
import { compact } from "intlayer";compact(1200); // "1.2K"compact("1000000", { locale: "fr", compactDisplay: "long" }); // "1 million"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:
Copiar el código al portapapeles
import { list } from "intlayer";list(["apple", "banana", "orange"]); // "apple, banana, and orange"list(["red", "green", "blue"], { locale: "fr", type: "disjunction" }); // "rouge, vert ou bleu"list([1, 2, 3], { type: "unit" }); // "1, 2, 3"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:
Copiar el código al portapapeles
// Código de la aplicación (recomendado)import { number, currency, date, relativeTime, units, compact, list, Intl, getLocaleName, getLocaleLang, getLocaleFromPath, getPathWithoutLocale, getLocalizedUrl, getHTMLTextDir, getContent, getTranslation, getIntlayer, getIntlayerAsync,} from "intlayer";React
Componentes cliente:
Copiar el código al portapapeles
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "react-intlayer/format";// o en aplicaciones Next.jsimport { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "next-intlayer/client/format";const MyComponent = () => { const number = useNumber(); const currency = useCurrency(); const date = useDate(); const percentage = usePercentage(); const compact = useCompact(); const list = useList(); const relativeTime = useRelativeTime(); const unit = useUnit(); return ( <div> <p>{number(123456.789)}</p> <p>{currency(1234.5, { currency: "EUR" })}</p> <p>{date(new Date(), "short")}</p> <p>{percentage(0.25)}</p> <p>{compact(1200)}</p> <p>{list(["apple", "banana", "orange"])}</p> <p>{relativeTime(new Date(), new Date() + 1000)}</p> <p>{unit(123456.789, { unit: "kilometer" })}</p> </div> );};Componentes del servidor (o tiempo de ejecución del servidor React):
Copiar el código al portapapeles
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "react-intlayer/server/format";// o en aplicaciones Next.jsimport { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "next-intlayer/server/format";Estos hooks considerarán la configuración regional desde elIntlayerProvideroIntlayerServerProvider
Vue
Componentes cliente:
Copiar el código al portapapeles
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "vue-intlayer/format";Esos composables considerarán la configuración regional del IntlayerProvider inyectado.