Задайте питання та отримайте підсумок документа, вказавши цю сторінку та обраного вами постачальника штучного інтелекту
Інтегрувавши Intlayer MCP Server у свого улюбленого AI-помічника, ви зможете отримувати всю документацію безпосередньо через ChatGPT, DeepSeek, Cursor, VSCode тощо.
Переглянути документацію MCP ServerІсторія версій
- Випуск компілятораv7.3.127.11.2025
Вміст цієї сторінки перекладено за допомогою штучного інтелекту.
Переглянути останню версію оригінального вмісту англійськоюЯкщо у вас є ідея щодо покращення цієї документації, будь ласка, долучіться, надіславши pull request на GitHub.
Посилання на документацію на GitHubСкопіювати документацію у форматі Markdown в буфер обміну
Intlayer Compiler | Автоматизоване витягування контенту для i18n
Що таке Intlayer Compiler?
The Intlayer Compiler — потужний інструмент, створений для автоматизації процесу інтернаціоналізації (i18n) у ваших додатках. Він сканує ваш вихідний код (JSX, TSX, Vue, Svelte) на наявність декларацій контенту, витягує їх і автоматично генерує необхідні файли словників. Це дозволяє зберігати контент поруч із компонентами, у той час як Intlayer займається керуванням та синхронізацією ваших словників.
Чому використовувати Intlayer Compiler?
- Automation: Усуває ручне копіювання та вставляння контенту у словники.
- Speed: Оптимізоване витягування контенту, яке забезпечує швидкість процесу збірки.
- Developer Experience: Тримайте декларації контенту там, де вони використовуються, що покращує підтримуваність.
- Live Updates: Підтримує Hot Module Replacement (HMR) для миттєвого зворотного зв'язку під час розробки.
Див. публікацію в блозі Compiler vs. Declarative i18n для детальнішого порівняння.
Чому не використовувати Intlayer Compiler?
Хоча компілятор надає відмінний досвід «just works», він також запроваджує певні компроміси, про які слід знати:
- Heuristic ambiguity: Компилятор має вгадувати, який контент призначений для користувача, а що — логіка додатка (наприклад, className="active", коди статусу, ідентифікатори продуктів). У складних кодових базах це може призводити до хибних спрацьовувань або пропущених рядків, що вимагатимуть ручних анотацій та винятків.
- Static-only extraction: Екстракція на основі компілятора спирається на статичний аналіз. Рядки, які існують лише під час виконання (коди помилок API, поля CMS тощо), не можуть бути виявлені або перекладені лише компілятором, тому вам усе одно потрібна додаткова стратегія i18n на рівні виконання.
Для більш глибокого архітектурного порівняння див. публікацію в блозі Compiler vs. Declarative i18n.
Як альтернативу, щоб автоматизувати ваш процес i18n і зберегти повний контроль над контентом, Intlayer також надає команду автоматичної екстракції intlayer transform (див. Документація CLI), або команду Intlayer: extract content to Dictionary з розширення Intlayer для VS Code (див. Документація розширення VS Code).
Використання
Vite
Для додатків на базі Vite (React, Vue, Svelte тощо) найпростіший спосіб використовувати компілятор — через плагін vite-intlayer.
Встановлення
npm install vite-intlayerНалаштування
Оновіть ваш vite.config.ts, щоб включити плагін intlayerCompiler:
Скопіюйте код у буфер обміну
import { defineConfig } from "vite";import { intlayer, intlayerCompiler } from "vite-intlayer";export default defineConfig({ plugins: [ intlayer(), intlayerCompiler(), // Додає плагін компілятора ],});Підтримка фреймворків
Плагін Vite автоматично визначає та обробляє різні типи файлів:
- React / JSX / TSX: Обробляються нативно.
- Vue: Потребує @intlayer/vue-compiler.
- Svelte: Потребує @intlayer/svelte-compiler.
Переконайтеся, що встановили відповідний пакет компілятора для вашого фреймворку:
# Для Vuenpm install @intlayer/vue-compiler# Для Sveltenpm install @intlayer/svelte-compilerNext.js (Babel)
Для Next.js або інших додатків на базі Webpack, що використовують Babel, ви можете налаштувати компілятор за допомогою плагіна @intlayer/babel.
Встановлення
npm install @intlayer/babelКонфігурація
Оновіть ваш babel.config.js (або babel.config.json), щоб додати плагін для екстракції. Ми надаємо хелпер getExtractPluginOptions, який автоматично завантажує вашу конфігурацію Intlayer.
Скопіюйте код у буфер обміну
const { intlayerExtractBabelPlugin, intlayerOptimizeBabelPlugin, getExtractPluginOptions, getOptimizePluginOptions,} = require("@intlayer/babel");module.exports = { presets: ["next/babel"], plugins: [ // Витягує контент з компонентів у словники [intlayerExtractBabelPlugin, getExtractPluginOptions()], // Оптимізує імпорти, замінюючи useIntlayer на прямі імпорти словників [intlayerOptimizeBabelPlugin, getOptimizePluginOptions()], ],};Ця конфігурація гарантує, що контент, оголошений у ваших компонентах, автоматично витягується й використовується для генерації словників під час процесу збірки.