Recibe notificaciones sobre los próximos lanzamientos de Intlayer
    Creación:2024-08-13Última actualización:2025-08-20

    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

    ts
    import {  Intl,  number,  percentage,  currency,  date,  relativeTime,  units,  compact,  list,  getLocaleName,  getLocaleLang,  getLocaleFromPath,  getPathWithoutLocale,  getLocalizedUrl,  getHTMLTextDir,  getContent,  getLocalisedContent,  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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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.):

    ts
    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)

    getLocalisedContent(node, locale, nodeProps, fallback?)

    Transforma un nodo de contenido solo con el plugin de traducción:

    ts
    import { getLocalisedContent } from "intlayer";const content = getLocalisedContent(  contentNode,  "fr",  { dictionaryKey: "common" },  true // usar locale predeterminado si falta la traducción);
    • node: El nodo de contenido a transformar
    • locale: El locale a usar para la traducción
    • nodeProps: Propiedades para el contexto de transformación
    • fallback: Indica si se debe usar el locale predeterminado como respaldo (por defecto es false)

    getTranslation(languageContent, locale?, fallback?)

    Extrae contenido para un locale específico de un objeto de contenido multilingüe:

    ts
    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:

    ts
    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:

    ts
    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:

    ts
    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, 2525%, 0.2525%).

    • value: number | string
    • options: Intl.NumberFormatOptions & { locale?: LocalesValues }

    Ejemplos:

    ts
    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")

    Ejemplos:

    ts
    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"

    Ejemplos:

    ts
    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 defecto new Date())
    • options: { locale?: LocalesValues; unit?: Intl.RelativeTimeFormatUnit; numeric?: Intl.RelativeTimeFormatNumeric; style?: Intl.RelativeTimeFormatStyle }
      • El valor predeterminado de unit es "second".

    Ejemplos:

    ts
    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

    Ejemplos:

    ts
    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 internamente notation: 'compact')

    Ejemplos:

    ts
    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'

    Ejemplos:

    ts
    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.defaultLocale si 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:

    ts
    // Código de la aplicación (recomendado)import {  number,  currency,  date,  relativeTime,  units,  compact,  list,  Intl,  getLocaleName,  getLocaleLang,  getLocaleFromPath,  getPathWithoutLocale,  getLocalizedUrl,  getHTMLTextDir,  getContent,  getLocalisedContent,  getTranslation,  getIntlayer,  getIntlayerAsync,} from "intlayer";

    React

    Componentes cliente:

    tsx
    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):

    ts
    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 el IntlayerProvider o IntlayerServerProvider

    Vue

    Componentes cliente:

    ts
    import {  useNumber,  useCurrency,  useDate,  usePercentage,  useCompact,  useList,  useRelativeTime,  useUnit,} from "vue-intlayer/format";

    Esos composables considerarán la configuración regional del IntlayerProvider inyectado.

    Historial de la documentación

    Versión Fecha Cambios
    5.8.0 2025-08-20 Añadidos formateadores para Vue
    5.8.0 2025-08-18 Añadida documentación de formateadores

    Componentes cliente:

    ts
    import {  useNumber,  useCurrency,  useDate,  usePercentage,  useCompact,  useList,  useRelativeTime,  useUnit,} from "vue-intlayer/format";

    Esos composables considerarán la configuración regional del IntlayerProvider inyectado

    Historial de la documentación

    Versión Fecha Cambios
    5.8.0 2025-08-20 Añadido formateadores de vue
    5.8.0 2025-08-18 Añadida documentación de formateadores
    5.8.0 2025-08-20 Añadida documentación del formateador de listas
    5.8.0 2025-08-20 Añadidas utilidades Intl adicionales (DisplayNames, Collator, PluralRules)
    5.8.0 2025-08-20 Añadidas utilidades de configuración regional (getLocaleName, getLocaleLang, getLocaleFromPath, etc.)
    5.8.0 2025-08-20 Añadidas utilidades para manejo de contenido (getContent, getTranslation, getIntlayer, etc.)
    Recibe notificaciones sobre los próximos lanzamientos de Intlayer