Задайте вопрос и получите краткое содержание документа через любого ИИ-провайдера на этой странице
Этот документ устарел, базовая версия была обновлена 20 января 2026 г..
Перейти к английской документацииИстория версий
- "Добавлены форматтеры для Vue"v5.8.020.08.2025
- "Добавлены форматтеры списка"v5.8.020.08.2025
- "Добавлены дополнительные утилиты Intl (DisplayNames, Collator, PluralRules)"v5.8.020.08.2025
- "Добавлены утилиты локали (getLocaleName, getLocaleLang, getLocaleFromPath и др.)"v5.8.020.08.2025
- "Добавлены утилиты для работы с контентом (getContent, getTranslation, getIntlayer и др.)"v5.8.020.08.2025
- "Добавлена документация по форматтерам"v5.8.018.08.2025
Содержимое этой страницы было переведено с помощью ИИ.
Смотреть последнюю версию оригинального контента на английскомIf 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
Форматтеры Intlayer
Обзор
Intlayer предоставляет набор лёгких помощников, построенных поверх нативных API Intl, а также кешированный обёртку Intl, чтобы избежать многократного создания тяжёлых форматтеров. Эти утилиты полностью учитывают локаль и могут использоваться из основного пакета intlayer.
Импорт
Копировать код в буфер обмена
import { Intl, number, percentage, currency, date, relativeTime, units, compact, list, getLocaleName, getLocaleLang, getLocaleFromPath, getPathWithoutLocale, getLocalizedUrl, getHTMLTextDir, getContent, getTranslation, getIntlayer, getIntlayerAsync,} from "intlayer";Если вы используете React, хуки также доступны; смотрите react-intlayer/format.
Кешированный Intl
Экспортируемый Intl, это тонкая кешированная обёртка вокруг глобального Intl. Он мемоизирует экземпляры NumberFormat, DateTimeFormat, RelativeTimeFormat, ListFormat, DisplayNames, Collator и PluralRules, что позволяет избежать повторного создания одного и того же форматтера.
Поскольку создание форматтера относительно дорогостоящее, такое кеширование улучшает производительность без изменения поведения. Обёртка предоставляет тот же API, что и нативный Intl, поэтому использование идентично.
- Кеширование происходит на уровне процесса и прозрачно для вызывающих.
Если Intl.DisplayNames недоступен в среде, выводится одно предупреждение только для разработчиков (рекомендуется использовать полифилл).
Примеры:
Копировать код в буфер обмена
import { Intl } from "intlayer";// Форматирование чиселconst numberFormat = new Intl.NumberFormat("en-GB", { style: "currency", currency: "GBP",});numberFormat.format(1234.5); // "£1,234.50"// Отображение названий языков, регионов и т.д.const displayNames = new Intl.DisplayNames("fr", { type: "language" });displayNames.of("en"); // "anglais"// Сортировка с учётом локалиconst collator = new Intl.Collator("fr", { sensitivity: "base" });collator.compare("é", "e"); // 0 (равны)// Правила множественного числаconst pluralRules = new Intl.PluralRules("fr");pluralRules.select(1); // "one"pluralRules.select(2); // "other"Дополнительные утилиты Intl
Помимо помощников для форматтеров, вы также можете использовать кешированную обёртку Intl напрямую для других возможностей Intl:
Intl.DisplayNames
Для локализованных названий языков, регионов, валют и систем письма:
Копировать код в буфер обмена
import { Intl } from "intlayer";const languageNames = new Intl.DisplayNames("en", { type: "language" });languageNames.of("fr"); // "French"const regionNames = new Intl.DisplayNames("fr", { type: "region" });regionNames.of("US"); // "États-Unis"Intl.Collator
Для локализованного сравнения и сортировки строк:
Копировать код в буфер обмена
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
Для определения форм множественного числа в разных локалях:
Копировать код в буфер обмена
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"Утилиты локалей
getLocaleName(displayLocale, targetLocale?)
Получает локализованное название локали на другом языке:
Копировать код в буфер обмена
import { getLocaleName } from "intlayer";getLocaleName("fr", "en"); // "French"getLocaleName("en", "fr"); // "anglais"getLocaleName("de", "es"); // "alemán"- displayLocale: Локаль, для которой нужно получить название
- targetLocale: Локаль, на которой будет отображаться название (по умолчанию displayLocale)
Доступные Composables
Все composables возвращают computed refs, которые автоматически используют локаль из внедренного IntlayerProvider.
Открыть таблицу в модальном окне для четкого просмотра всех данных
| Composable | Описание | Пример вывода |
|---|---|---|
useNumber() | Форматирование чисел с группировкой | "123,456.789" |
useCurrency() | Форматирование значений валют | "€1,234.50" |
usePercentage() | Форматирование процентов | "25%" |
useDate() | Форматирование дат и времени | "Aug 2, 2025" |
useRelativeTime() | Форматирование относительного времени | "in 3 days" |
useUnit() | Форматирование значений с единицами | "5 kilometers" |
useCompact() | Форматирование чисел в компактной нотации | "1.2K" |
useList() | Форматирование массивов как списки | "apple, banana, and orange" |
useIntl() | Получить привязанный к локали объект Intl | Полный доступ к Intl API |
Полный пример
Копировать код в буфер обмена
<script setup>import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "vue-intlayer/format";const number = useNumber();const currency = useCurrency();const date = useDate();const percentage = usePercentage();const compact = useCompact();const list = useList();const relativeTime = useRelativeTime();const unit = useUnit();</script><template> <div> <p>{{ number.value(123456.789) }}</p> <p>{{ currency.value(1234.5, { currency: "EUR" }) }}</p> <p>{{ date.value(new Date(), "short") }}</p> <p>{{ percentage.value(0.25) }}</p> <p>{{ compact.value(1200) }}</p> <p>{{ list.value(["apple", "banana", "orange"]) }}</p> <p>{{ relativeTime.value(new Date(), new Date(Date.now() + 86400000)) }}</p> <p>{{ unit.value(5, { unit: "kilometer" }) }}</p> </div></template>Composable useIntl
Composable useIntl предоставляет прямой доступ к объекту Intl, привязанному к локали. Это полезно, когда вам нужен полный API Intl с автоматическим внедрением локали.
Копировать код в буфер обмена
<script setup>import { useIntl } from "vue-intlayer/format";const intl = useIntl(); // использует локаль контекста// Стандартный API Intl, но локаль автоматически внедряется, если не определенаconst formatted = new intl.value.NumberFormat(undefined, { style: "currency", currency: "USD",}).format(123.45);// Вы все еще можете переопределить локаль, если необходимоconst date = new intl.value.DateTimeFormat("fr-FR").format(new Date());// Доступ к другим функциям Intlconst displayNames = new intl.value.DisplayNames(undefined, { type: "language",});const languageName = displayNames.of("fr");</script><template> <div> <p>{{ formatted }}</p> <p>{{ date }}</p> <p>{{ languageName }}</p> </div></template>Vanilla JS / Node.js Formatters
Для контекстов без framework'а импортируйте форматтеры напрямую из intlayer. Обратите внимание, что вы должны передать locale вручную.
getLocaleLang(locale?)
Извлекает код языка из строки локали:
Копировать код в буфер обмена
import { getLocaleLang } from "intlayer";getLocaleLang("en-US"); // "en"getLocaleLang("fr-CA"); // "fr"getLocaleLang("de"); // "de"- locale: Локаль, из которой нужно извлечь язык (по умолчанию текущая локаль)
Функции форматирования
getLocaleFromPath(inputUrl)
Извлекает сегмент локали из URL или пути:
Копировать код в буфер обмена
import { getLocaleFromPath } from "intlayer";getLocaleFromPath("/en/dashboard"); // "en"getLocaleFromPath("/fr/dashboard"); // "fr"getLocaleFromPath("/dashboard"); // "en" (локаль по умолчанию)getLocaleFromPath("https://example.com/es/about"); // "es"- inputUrl: Полная строка URL или путь для обработки
- returns: Обнаруженная локаль или локаль по умолчанию, если локаль не найдена
getPathWithoutLocale(inputUrl, locales?)
Удаляет сегмент локали из URL или пути:
Копировать код в буфер обмена
import { getPathWithoutLocale } from "intlayer";getPathWithoutLocale("/en/dashboard"); // "/dashboard"getPathWithoutLocale("/fr/dashboard"); // "/dashboard"getPathWithoutLocale("https://example.com/en/about"); // "https://example.com/about"- inputUrl: Полная строка URL или путь для обработки
- locales: Необязательный массив поддерживаемых локалей (по умолчанию используется настроенный список локалей)
- returns: URL без сегмента локали
getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)
Генерирует локализованный URL для текущей локали:
Копировать код в буфер обмена
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: Исходный URL для локализации
- currentLocale: Текущая локаль
- locales: Необязательный массив поддерживаемых локалей (по умолчанию используется настроенный список локалей)
- defaultLocale: Необязательная локаль по умолчанию (по умолчанию используется настроенная локаль по умолчанию)
- prefixDefault: Добавлять ли префикс для локали по умолчанию (по умолчанию используется настроенное значение)
getHTMLTextDir(locale?)
Возвращает направление текста для локали:
Копировать код в буфер обмена
import { getHTMLTextDir } from "intlayer";getHTMLTextDir("en-US"); // "ltr"getHTMLTextDir("ar"); // "rtl"getHTMLTextDir("he"); // "rtl"- locale: Локаль, для которой нужно получить направление текста (по умолчанию текущая локаль)
- returns:
"ltr","rtl"или"auto"
Утилиты для обработки контента
getContent(node, nodeProps, locale?)
Преобразует узел контента со всеми доступными плагинами (перевод, перечисление, вставка и т.д.):
Копировать код в буфер обмена
import { getContent } from "intlayer";const content = getContent( contentNode, { dictionaryKey: "common", dictionaryPath: "/path/to/dict" }, "fr");- node: Узел контента для преобразования
- nodeProps: Свойства для контекста преобразования
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
getTranslation(languageContent, locale?, fallback?)
Извлекает контент для конкретной локали из объекта с языковым содержимым:
Копировать код в буфер обмена
import { getTranslation } from "intlayer";const content = getTranslation( { en: "Hello", fr: "Bonjour", de: "Hallo", }, "fr", true); // "Bonjour"- languageContent: Объект, сопоставляющий локали с контентом
- locale: Целевая локаль (по умолчанию используется настроенная локаль по умолчанию)
- fallback: Использовать ли резервный вариант с локалью по умолчанию (по умолчанию true)
getIntlayer(dictionaryKey, locale?, plugins?)
Получает и преобразует контент из словаря по ключу:
Копировать код в буфер обмена
import { getIntlayer } from "intlayer";const content = getIntlayer("common", "fr");const nestedContent = getIntlayer("common", "fr", customPlugins);- dictionaryKey: Ключ словаря для получения
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
- plugins: Необязательный массив пользовательских плагинов трансформации
Cached Intl
Экспортируемый Intl из intlayer — это кэшированная обёртка вокруг глобального Intl. Она мемоизирует экземпляры форматтеров (NumberFormat, DateTimeFormat и т. д.), чтобы избежать их повторного создания и улучшить производительность.
Копировать код в буфер обмена
import { Intl } from "intlayer";// Форматирование чиселconst numberFormat = new Intl.NumberFormat("en-GB", { style: "currency", currency: "GBP",});numberFormat.format(1234.5); // "£1,234.50"// Отображение названий языков, регионов и т. д.const displayNames = new Intl.DisplayNames("fr", { type: "language" });displayNames.of("en"); // "anglais"// Сортировка по правилам коллацииconst collator = new Intl.Collator("fr", { sensitivity: "base" });collator.compare("é", "e"); // 0 (equal)// Правила pluralsconst pluralRules = new Intl.PluralRules("fr");pluralRules.select(1); // "one"pluralRules.select(2); // "other"Дополнительные возможности Intl
getIntlayerAsync(dictionaryKey, locale?, plugins?)
Асинхронно получает контент из удалённого словаря:
Копировать код в буфер обмена
import { getIntlayerAsync } from "intlayer";const content = await getIntlayerAsync("common", "fr");- dictionaryKey: Ключ словаря для получения
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
- plugins: Необязательный массив пользовательских плагинов трансформации
Форматтеры
Все ниже перечисленные помощники экспортируются из intlayer.
number(value, options?)
Форматирует числовое значение с учетом локали, группировки и десятичных знаков.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Примеры:
Копировать код в буфер обмена
import { number } from "intlayer";number(123456.789); // "123,456.789" (в en-US)number("1000000", { locale: "fr" }); // "1 000 000"number(1234.5, { minimumFractionDigits: 2 }); // "1,234.50"Утилиты Локализации
percentage(value, options?)
Форматирует число в строку с процентами.
Поведение: значения больше 1 интерпретируются как целые проценты и нормализуются (например, 25 → 25%, 0.25 → 25%).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Примеры:
Копировать код в буфер обмена
import { percentage } from "intlayer";percentage(0.25); // "25%"percentage(25); // "25%"percentage(0.237, { minimumFractionDigits: 1 }); // "23.7%"currency(value, options?)
Форматирует значение как локализованную валюту. По умолчанию используется USD с двумя десятичными знаками.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- Общие поля:
currency(например,"EUR"),currencyDisplay("symbol" | "code" | "name")
- Общие поля:
Примеры:
Копировать код в буфер обмена
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?)
Форматирует значение даты/времени с помощью Intl.DateTimeFormat.
- date:
Date | string | number - optionsOrPreset:
Intl.DateTimeFormatOptions & { locale?: LocalesValues }или один из предустановленных вариантов:- Предустановки:
"short" | "long" | "dateOnly" | "timeOnly" | "full"
- Предустановки:
Примеры:
Копировать код в буфер обмена
import { date } from "intlayer";date(new Date(), "short"); // например, "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?)
Форматирует относительное время между двумя моментами с помощью Intl.RelativeTimeFormat.
- Передайте "now" в качестве первого аргумента и целевой момент вторым, чтобы получить естественную формулировку.
- from:
Date | string | number - to:
Date | string | number(по умолчаниюnew Date()) - options:
{ locale?: LocalesValues; unit?: Intl.RelativeTimeFormatUnit; numeric?: Intl.RelativeTimeFormatNumeric; style?: Intl.RelativeTimeFormatStyle }- По умолчанию
unitравен"second".
- По умолчанию
Примеры:
Копировать код в буфер обмена
import { relativeTime } from "intlayer";const now = new Date();const in3Days = new Date(now.getTime() + 3 * 864e5);relativeTime(now, in3Days, { unit: "day" }); // "через 3 дня"const twoHoursAgo = new Date(now.getTime() - 2 * 3600e3);relativeTime(now, twoHoursAgo, { unit: "hour", numeric: "auto" }); // "2 часа назад"units(value, options?)
Форматирует числовое значение как локализованную строку с единицей измерения, используя Intl.NumberFormat с style: 'unit'.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- Общие поля:
unit(например,"kilometer","byte"),unitDisplay("short" | "narrow" | "long") - Значения по умолчанию:
unit: 'day',unitDisplay: 'short',useGrouping: false
- Общие поля:
Примеры:
Копировать код в буфер обмена
import { units } from "intlayer";units(5, { unit: "kilometer", unitDisplay: "long", locale: "en-GB" }); // "5 kilometers"units(1024, { unit: "byte", unitDisplay: "narrow" }); // "1,024B" (зависит от локали)compact(value, options?)
Форматирует число с использованием компактной нотации (например, 1.2K, 1M).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }(используетnotation: 'compact'под капотом)
Примеры:
Копировать код в буфер обмена
import { compact } from "intlayer";compact(1200); // "1.2K"compact("1000000", { locale: "fr", compactDisplay: "long" }); // "1 million"Утилиты для обработки содержимого
list(values, options?)
Форматирует массив значений в локализованную строку списка с использованием Intl.ListFormat.
- values:
(string | number)[] - options:
Intl.ListFormatOptions & { locale?: LocalesValues }- Общие поля:
type("conjunction" | "disjunction" | "unit"),style("long" | "short" | "narrow") - Значения по умолчанию:
type: 'conjunction',style: 'long'
- Общие поля:
Примеры:
Копировать код в буфер обмена
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"React
Клиентские компоненты:
Копировать код в буфер обмена
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "react-intlayer/format";// или в приложениях 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> );};Серверные компоненты (или React Server runtime):
Копировать код в буфер обмена
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "react-intlayer/server/format";// или в приложениях Next.jsimport { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "next-intlayer/server/format";Эти хуки будут учитывать локаль изIntlayerProviderилиIntlayerServerProvider
Vue
Клиентские компоненты:
Копировать код в буфер обмена
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "vue-intlayer/format";Эти композиции будут учитывать локаль из внедренного IntlayerProvider
Компоненты клиента:
Копировать код в буфер обмена
import { useNumber, useCurrency, useDate, usePercentage, useCompact, useList, useRelativeTime, useUnit,} from "vue-intlayer/format";Эти композиционные функции будут учитывать локаль из внедренного IntlayerProvider
Примечания
- Все вспомогательные функции принимают входные данные типа
string; они внутренне преобразуются в числа или даты. - Локаль по умолчанию использует ваш настроенный
internationalization.defaultLocale, если не указана. - Эти утилиты являются тонкими оболочками; для продвинутого форматирования передавайте стандартные параметры
Intl.