---
createdAt: 2024-08-13
updatedAt: 2025-10-14
title: Форматери
description: Засоби форматування, орієнтовані на локаль, на основі Intl для чисел, відсотків, валют, дат, відносного часу, одиниць та компактного представлення. Містить кешований хелпер Intl.
keywords:
- Форматери
- Intl
- Числа
- Валюта
- Відсотки
- Дати
- Відносний час
- Одиниці
- Компактне представлення
- Список
- Інтернаціоналізація
slugs:
- doc
- formatters
history:
- version: 6.2.0
date: 2025-10-14
changes: Видалено getIntlayerAsync з форматерів
- version: 5.8.0
date: 2025-08-20
changes: Додано форматери для Vue
- version: 5.8.0
date: 2025-08-18
changes: Додано документацію щодо форматерів
- version: 5.8.0
date: 2025-08-20
changes: Додано документацію для форматера списків
- version: 5.8.0
date: 2025-08-20
changes: Додано додаткові утиліти Intl (DisplayNames, Collator, PluralRules)
- version: 5.8.0
date: 2025-08-20
changes: Додано утиліти для локалі (getLocaleName, getLocaleLang, getLocaleFromPath тощо)
- version: 5.8.0
date: 2025-08-20
changes: Додано утиліти обробки контенту (getContent, getTranslation, getIntlayer тощо)
---
# Форматери Intlayer
## Зміст
## Огляд
Intlayer надає набір легких хелперів, побудованих поверх рідних API `Intl`, а також кешований обгорток `Intl`, щоб уникнути повторного створення важких форматерів. Ці утиліти повністю враховують локаль і можуть використовуватися з основного пакета `intlayer`.
### Імпорт
```ts
import {
Intl,
number,
percentage,
currency,
date,
relativeTime,
units,
compact,
list,
getLocaleName,
getLocaleLang,
getLocaleFromPath,
getPathWithoutLocale,
getLocalizedUrl,
getHTMLTextDir,
getContent,
getTranslation,
getIntlayer,
} from "intlayer";
```
If you are using React, hooks are also available; see `react-intlayer/format`.
## Cached Intl
The exported `Intl` is a thin, cached wrapper around the global `Intl`. It memoizes instances of `NumberFormat`, `DateTimeFormat`, `RelativeTimeFormat`, `ListFormat`, `DisplayNames`, `Collator`, and `PluralRules`, which avoids rebuilding the same formatter repeatedly.
Because formatter construction is relatively expensive, this caching improves performance without changing behavior. The wrapper exposes the same API as the native `Intl`, so usage is identical.
- Кешування здійснюється на рівні процесу й є прозорим для викликачів.
> Якщо `Intl.DisplayNames` недоступний у середовищі, виводиться одне попередження лише для розробників (розгляньте можливість поліфілу).
Приклади:
```ts
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); // "інше"
```
## Додаткові утиліти Intl
Окрім допоміжних форматерів, ви також можете безпосередньо використовувати кешований обгорток Intl для інших можливостей Intl:
### `Intl.DisplayNames`
Для локалізованих назв мов, регіонів, валют та писемностей:
```ts
import { Intl } from "intlayer";
const languageNames = new Intl.DisplayNames("en", { type: "language" });
languageNames.of("fr"); // "французька"
const regionNames = new Intl.DisplayNames("fr", { type: "region" });
regionNames.of("US"); // "Сполучені Штати"
```
### `Intl.Collator`
Для порівняння рядків та сортування з урахуванням локалі:
```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`
Для визначення форм множини в різних локалях:
```ts
import { Intl } from "intlayer";
const pluralRules = new Intl.PluralRules("ar");
pluralRules.select(0); // "нуль"
pluralRules.select(1); // "один"
pluralRules.select(2); // "два"
pluralRules.select(3); // "кілька"
pluralRules.select(11); // "багато"
```
## Утиліти локалей
### `getLocaleName(displayLocale, targetLocale?)`
Отримує локалізовану назву локалі в іншій локалі:
```ts
import { getLocaleName } from "intlayer";
getLocaleName("fr", "en"); // англійською: "French"
getLocaleName("en", "fr"); // французькою: "anglais"
getLocaleName("de", "es"); // іспанською: "alemán"
```
- **displayLocale**: Локаль, для якої потрібно отримати назву
- **targetLocale**: Локаль, в якій відображається назва (за замовчуванням displayLocale)
### `getLocaleLang(locale?)`
Витягує код мови з рядка локалі:
```ts
import { getLocaleLang } from "intlayer";
getLocaleLang("en-US"); // "en"
getLocaleLang("fr-CA"); // "fr"
getLocaleLang("de"); // "de"
```
- **locale**: Локаль, з якої потрібно витягти код мови (за замовчуванням поточна локаль)
### `getLocaleFromPath(inputUrl)`
Витягує сегмент локалі з URL або шляху:
```ts
import { getLocaleFromPath } from "intlayer";
getLocaleFromPath("/en/dashboard"); // "en"
getLocaleFromPath("/fr/dashboard"); // "fr"
getLocaleFromPath("/dashboard"); // "en" (default locale)
getLocaleFromPath("https://example.com/es/about"); // "es"
```
- **inputUrl**: Повний рядок URL або шлях (pathname) для обробки
- **returns**: Виявлена локаль або локаль за замовчуванням, якщо локаль не знайдена
### `getPathWithoutLocale(inputUrl, locales?)`
Видаляє сегмент локалі з URL або шляху (pathname):
```ts
import { getPathWithoutLocale } from "intlayer";
getPathWithoutLocale("/en/dashboard"); // "/dashboard"
getPathWithoutLocale("/fr/dashboard"); // "/dashboard"
getPathWithoutLocale("https://example.com/en/about"); // "https://example.com/about"
```
- **inputUrl**: Повний рядок URL або шлях (pathname) для обробки
- **locales**: Необов'язковий масив підтримуваних локалей (за замовчуванням використовується сконфігурований список локалей)
- **returns**: URL без сегменту локалі
### `getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)`
Генерує локалізований URL для поточної локалі:
```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**: Початковий URL для локалізації
- **currentLocale**: Поточна локаль
- **locales**: Необов'язковий масив підтримуваних локалей (за замовчуванням — сконфігуровані локалі)
- **defaultLocale**: Необов'язкова локаль за замовчуванням (за замовчуванням — сконфігурована локаль за замовчуванням)
- **prefixDefault**: Чи додавати префікс для локалі за замовчуванням (за замовчуванням — сконфігуроване значення)
### `getHTMLTextDir(locale?)`
Повертає напрямок тексту для локалі:
```ts
import { getHTMLTextDir } from "intlayer";
getHTMLTextDir("en-US"); // повертає "ltr"
getHTMLTextDir("ar"); // повертає "rtl"
getHTMLTextDir("he"); // повертає "rtl"
```
- **locale**: Локаль, для якої потрібно отримати напрямок тексту (за замовчуванням — поточна локаль)
- **повертає**: `"ltr"`, `"rtl"`, або `"auto"`
## Утиліти обробки контенту
### `getContent(node, nodeProps, locale?)`
Перетворює вузол контенту за допомогою всіх доступних плагінів (translation, enumeration, insertion тощо):
```ts
import { getContent } from "intlayer";
const content = getContent(
contentNode,
{ dictionaryKey: "common", dictionaryPath: "/path/to/dict" },
"fr"
);
```
- **node**: Вузол контенту, який потрібно перетворити
- **nodeProps**: Властивості для контексту перетворення
- **locale**: Необов'язкова локаль (за замовчуванням використовується налаштована локаль)
### `getTranslation(languageContent, locale?, fallback?)`
Витягує вміст для конкретної локалі з об'єкта мовного вмісту:
```ts
import { getTranslation } from "intlayer";
const content = getTranslation(
{
en: "Hello",
fr: "Bonjour",
de: "Hallo",
},
"fr",
true
); // "Bonjour"
```
- **languageContent**: Об'єкт, що відображає локалі на відповідний вміст
- **locale**: Цільова локаль (за замовчуванням використовується налаштована локаль)
- **fallback**: Чи виконувати відкат до локалі за замовчуванням (за замовчуванням true)
### `getIntlayer(dictionaryKey, locale?, plugins?)`
Отримує та трансформує вміст із словника за ключем:
```ts
import { getIntlayer } from "intlayer";
const content = getIntlayer("common", "fr");
const nestedContent = getIntlayer("common", "fr", customPlugins);
```
- **dictionaryKey**: Ключ словника, який необхідно отримати
- **locale**: Необов'язкова локаль (за замовчуванням — налаштована локаль за замовчуванням)
- **plugins**: Необов'язковий масив кастомних плагінів трансформації
## Форматувачі
Усі допоміжні функції нижче експортуються з `intlayer`.
### `number(value, options?)`
Форматує числове значення з урахуванням локалі для групування та десяткових знаків.
- **value**: `number | string`
- **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }`
Examples:
```ts
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 }`
Приклади:
```ts
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"`)
Приклади:
```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?)`
Форматує значення дати/часу за допомогою `Intl.DateTimeFormat`.
- **date**: `Date | string | number`
- **optionsOrPreset**: `Intl.DateTimeFormatOptions & { locale?: LocalesValues }` або один із пресетів:
- Presets: `"short" | "long" | "dateOnly" | "timeOnly" | "full"`
Приклади:
```ts
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"`.
Приклади:
```ts
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`
Приклади:
```ts
import { units } from "intlayer";
units(5, { unit: "kilometer", unitDisplay: "long", locale: "en-GB" }); // "5 кілометрів"
units(1024, { unit: "byte", unitDisplay: "narrow" }); // "1,024B" (залежить від локалі)
```
### `compact(value, options?)`
Форматує число з використанням компактної нотації (наприклад, `1.2K`, `1M`).
- **value**: `number | string`
- **options**: `Intl.NumberFormatOptions & { locale?: LocalesValues }` (використовує `notation: 'compact'` під капотом)
Приклади:
```ts
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'`
Приклади:
```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"
```
## Примітки
- Усі утиліти приймають вхідні значення як `string`; всередині вони приводяться до чисел або дат.
- Якщо локаль не вказана, за замовчуванням використовується налаштована вами `internationalization.defaultLocale`.
- Ці утиліти — тонкі обгортки; для просунутого форматування передавайте стандартні опції `Intl`.
## Точки входу та повторні експорти (`@index.ts`)
Форматери містяться в core-пакеті і реекспортуються з пакетів вищого рівня, щоб зробити імпорти зручними в різних середовищах виконання:
Приклади:
```ts
// Код додатку (рекомендовано)
import {
number,
currency,
date,
relativeTime,
units,
compact,
list,
Intl,
getLocaleName,
getLocaleLang,
getLocaleFromPath,
getPathWithoutLocale,
getLocalizedUrl,
getHTMLTextDir,
getContent,
getTranslation,
getIntlayer,
} from "intlayer";
```
### React
Клієнтські компоненти:
```tsx
import {
useNumber,
useCurrency,
useDate,
usePercentage,
useCompact,
useList,
useRelativeTime,
useUnit,
} from "react-intlayer/format";
// або в Preact-додатках
// "preact-intlayer/format";
// або в Next.js-додатках
// "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 (
{number(123456.789)}
{currency(1234.5, { currency: "EUR" })}
{date(new Date(), "short")}
{percentage(0.25)}
{compact(1200)}
{list(["apple", "banana", "orange"])}
{relativeTime(new Date(), new Date() + 1000)}
{unit(123456.789, { unit: "kilometer" })}
);
};
```
Серверні компоненти (або React Server runtime):
```ts
import {
useNumber,
useCurrency,
useDate,
usePercentage,
useCompact,
useList,
useRelativeTime,
useUnit,
} from "react-intlayer/server/format";
// або в додатках Next.js
import {
useNumber,
useCurrency,
useDate,
usePercentage,
useCompact,
useList,
useRelativeTime,
useUnit,
} from "next-intlayer/server/format";
```
> Ці хуки братимуть до уваги локаль із `IntlayerProvider` або `IntlayerServerProvider`
### Vue
Клієнтські компоненти:
```ts
import {
useNumber,
useCurrency,
useDate,
usePercentage,
useCompact,
useList,
useRelativeTime,
useUnit,
} from "vue-intlayer/format";
```
> Ці composables братимуть до уваги локаль із ін'єктованого `IntlayerProvider`