Спросите свой вопрос и получите сводку документа, используя эту страницу и выбранного вами поставщика AI
Этот документ устарел, базовая версия была обновлена 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
Содержимое этой страницы было переведено с помощью ИИ.
Смотреть последнюю версию оригинального контента на английскомЕсли у вас есть идея по улучшению этой документации, не стесняйтесь внести свой вклад, подав запрос на вытягивание на GitHub.
Ссылка на документацию GitHubКопировать Markdown документа в буфер обмена
Форматтеры Intlayer
Обзор
Intlayer предоставляет набор лёгких помощников, построенных поверх нативных API Intl, а также кешированный обёртку Intl, чтобы избежать многократного создания тяжёлых форматтеров. Эти утилиты полностью учитывают локаль и могут использоваться из основного пакета intlayer.
Импорт
Если вы используете React, хуки также доступны; смотрите react-intlayer/format.
Кешированный Intl
Экспортируемый Intl, это тонкая кешированная обёртка вокруг глобального Intl. Он мемоизирует экземпляры NumberFormat, DateTimeFormat, RelativeTimeFormat, ListFormat, DisplayNames, Collator и PluralRules, что позволяет избежать повторного создания одного и того же форматтера.
Поскольку создание форматтера относительно дорогостоящее, такое кеширование улучшает производительность без изменения поведения. Обёртка предоставляет тот же API, что и нативный Intl, поэтому использование идентично.
- Кеширование происходит на уровне процесса и прозрачно для вызывающих.
Если Intl.DisplayNames недоступен в среде, выводится одно предупреждение только для разработчиков (рекомендуется использовать полифилл).
Примеры:
Дополнительные утилиты Intl
Помимо помощников для форматтеров, вы также можете использовать кешированную обёртку Intl напрямую для других возможностей Intl:
Intl.DisplayNames
Для локализованных названий языков, регионов, валют и систем письма:
Intl.Collator
Для локализованного сравнения и сортировки строк:
Intl.PluralRules
Для определения форм множественного числа в разных локалях:
Утилиты локалей
getLocaleName(displayLocale, targetLocale?)
Получает локализованное название локали на другом языке:
- displayLocale: Локаль, для которой нужно получить название
- targetLocale: Локаль, на которой будет отображаться название (по умолчанию displayLocale)
getLocaleLang(locale?)
Извлекает код языка из строки локали:
- locale: Локаль, из которой нужно извлечь язык (по умолчанию текущая локаль)
getLocaleFromPath(inputUrl)
Извлекает сегмент локали из URL или пути:
- inputUrl: Полная строка URL или путь для обработки
- returns: Обнаруженная локаль или локаль по умолчанию, если локаль не найдена
getPathWithoutLocale(inputUrl, locales?)
Удаляет сегмент локали из URL или пути:
- inputUrl: Полная строка URL или путь для обработки
- locales: Необязательный массив поддерживаемых локалей (по умолчанию используется настроенный список локалей)
- returns: URL без сегмента локали
getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)
Генерирует локализованный URL для текущей локали:
- url: Исходный URL для локализации
- currentLocale: Текущая локаль
- locales: Необязательный массив поддерживаемых локалей (по умолчанию используется настроенный список локалей)
- defaultLocale: Необязательная локаль по умолчанию (по умолчанию используется настроенная локаль по умолчанию)
- prefixDefault: Добавлять ли префикс для локали по умолчанию (по умолчанию используется настроенное значение)
getHTMLTextDir(locale?)
Возвращает направление текста для локали:
- locale: Локаль, для которой нужно получить направление текста (по умолчанию текущая локаль)
- returns:
"ltr","rtl"или"auto"
Утилиты для обработки контента
getContent(node, nodeProps, locale?)
Преобразует узел контента со всеми доступными плагинами (перевод, перечисление, вставка и т.д.):
- node: Узел контента для преобразования
- nodeProps: Свойства для контекста преобразования
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
getTranslation(languageContent, locale?, fallback?)
Извлекает контент для конкретной локали из объекта с языковым содержимым:
- languageContent: Объект, сопоставляющий локали с контентом
- locale: Целевая локаль (по умолчанию используется настроенная локаль по умолчанию)
- fallback: Использовать ли резервный вариант с локалью по умолчанию (по умолчанию true)
getIntlayer(dictionaryKey, locale?, plugins?)
Получает и преобразует контент из словаря по ключу:
- dictionaryKey: Ключ словаря для получения
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
- plugins: Необязательный массив пользовательских плагинов трансформации
getIntlayerAsync(dictionaryKey, locale?, plugins?)
Асинхронно получает контент из удалённого словаря:
- dictionaryKey: Ключ словаря для получения
- locale: Необязательная локаль (по умолчанию используется настроенная локаль по умолчанию)
- plugins: Необязательный массив пользовательских плагинов трансформации
Форматтеры
Все ниже перечисленные помощники экспортируются из intlayer.
number(value, options?)
Форматирует числовое значение с учетом локали, группировки и десятичных знаков.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Примеры:
percentage(value, options?)
Форматирует число в строку с процентами.
Поведение: значения больше 1 интерпретируются как целые проценты и нормализуются (например, 25 → 25%, 0.25 → 25%).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
Примеры:
currency(value, options?)
Форматирует значение как локализованную валюту. По умолчанию используется USD с двумя десятичными знаками.
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- Общие поля:
currency(например,"EUR"),currencyDisplay("symbol" | "code" | "name")
- Общие поля:
Примеры:
date(date, optionsOrPreset?)
Форматирует значение даты/времени с помощью Intl.DateTimeFormat.
- date:
Date | string | number - optionsOrPreset:
Intl.DateTimeFormatOptions & { locale?: LocalesValues }или один из предустановленных вариантов:- Предустановки:
"short" | "long" | "dateOnly" | "timeOnly" | "full"
- Предустановки:
Примеры:
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".
- По умолчанию
Примеры:
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
- Общие поля:
Примеры:
compact(value, options?)
Форматирует число с использованием компактной нотации (например, 1.2K, 1M).
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }(используетnotation: 'compact'под капотом)
Примеры:
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'
- Общие поля:
Примеры:
React
Клиентские компоненты:
Серверные компоненты (или React Server runtime):
Эти хуки будут учитывать локаль изIntlayerProviderилиIntlayerServerProvider
Vue
Клиентские компоненты:
Эти композиции будут учитывать локаль из внедренного IntlayerProvider
Компоненты клиента:
Эти композиционные функции будут учитывать локаль из внедренного IntlayerProvider