Отримуйте сповіщення про майбутні випуски Intlayer
    Дата створення:2025-09-09Останнє оновлення:2025-09-09

    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:

    vite.config.ts
    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-compiler

    Next.js (Babel)

    Для Next.js або інших додатків на базі Webpack, що використовують Babel, ви можете налаштувати компілятор за допомогою плагіна @intlayer/babel.

    Встановлення

    npm install @intlayer/babel

    Конфігурація

    Оновіть ваш babel.config.js (або babel.config.json), щоб додати плагін для екстракції. Ми надаємо хелпер getExtractPluginOptions, який автоматично завантажує вашу конфігурацію Intlayer.

    babel.config.js
    const {  intlayerExtractBabelPlugin,  intlayerOptimizeBabelPlugin,  getExtractPluginOptions,  getOptimizePluginOptions,} = require("@intlayer/babel");module.exports = {  presets: ["next/babel"],  plugins: [    // Витягує контент з компонентів у словники    [intlayerExtractBabelPlugin, getExtractPluginOptions()],    // Оптимізує імпорти, замінюючи useIntlayer на прямі імпорти словників    [intlayerOptimizeBabelPlugin, getOptimizePluginOptions()],  ],};

    Ця конфігурація гарантує, що контент, оголошений у ваших компонентах, автоматично витягується й використовується для генерації словників під час процесу збірки.

    Отримуйте сповіщення про майбутні випуски Intlayer