Zadaj pytanie i otrzymaj streszczenie dokumentu, odwołując się do tej strony i wybranego dostawcy AI
Historia wersji
- "Aktualizacja opcji kompilatora, dodanie wsparcia dla FilePathPattern"v8.2.09.03.2026
- "Aktualizacja opcji kompilatora"v8.1.725.02.2026
- "Wydanie kompilatora"v7.3.127.11.2025
Treść tej strony została przetłumaczona przy użyciu sztucznej inteligencji.
Zobacz ostatnią wersję oryginalnej treści w języku angielskimJeśli masz pomysł na ulepszenie tej dokumentacji, zachęcamy do przesłania pull requesta na GitHubie.
Link do dokumentacji na GitHubieKopiuj dokument Markdown do schowka
Intlayer Compiler | Zautomatyzowane wydobywanie treści dla i18n
Czym jest Intlayer Compiler?
Intlayer Compiler to potężne narzędzie zaprojektowane w celu automatyzacji procesu internacjonalizacji (i18n) w Twoich aplikacjach. Przeszukuje Twój kod źródłowy (JSX, TSX, Vue, Svelte) w poszukiwaniu deklaracji treści, wydobywa je i automatycznie generuje niezbędne pliki słowników. Pozwala to na utrzymanie treści współlokalnie z komponentami, podczas gdy Intlayer zajmuje się zarządzaniem i synchronizacją Twoich słowników.
Dlaczego warto używać Intlayer Compiler?
- Automatyzacja: Eliminuje ręczne kopiowanie i wklejanie treści do słowników.
- Szybkość: Optymalizowane wydobywanie treści zapewnia szybki proces budowania.
- Doświadczenie programisty: Zachowaj deklaracje treści dokładnie tam, gdzie są używane, co poprawia utrzymanie kodu.
- Aktualizacje na żywo: Obsługuje Hot Module Replacement (HMR) dla natychmiastowej informacji zwrotnej podczas tworzenia aplikacji.
Zobacz wpis na blogu Compiler vs. Declarative i18n dla głębszego porównania.
Dlaczego nie używać Intlayer Compiler?
Chociaż kompilator oferuje doskonałe doświadczenie "działa od razu", wprowadza również pewne kompromisy, o których powinieneś wiedzieć:
- Niejednoznaczność heurystyczna: Kompilator musi zgadywać, co jest treścią skierowaną do użytkownika, a co logiką aplikacji (np.
className="active", kody statusu, ID produktów). W złożonych bazach kodu może to prowadzić do fałszywych pozytywów lub pominiętych ciągów znaków, które wymagają ręcznych adnotacji i wyjątków. - Tylko statyczna ekstrakcja: Ekstrakcja oparta na kompilatorze opiera się na analizie statycznej. Ciągi znaków, które istnieją tylko w czasie wykonywania (kody błędów API, pola CMS itp.), nie mogą być odkryte ani przetłumaczone przez sam kompilator, więc nadal potrzebujesz uzupełniającej strategii i18n czasu wykonywania.
Aby uzyskać głębsze porównanie architektoniczne, zobacz wpis na blogu Compiler vs. Declarative i18n.
Jako alternatywę, aby zautomatyzować proces i18n przy zachowaniu pełnej kontroli nad treścią, Intlayer zapewnia również polecenie auto-ekstrakcji intlayer extract (zobacz dokumentację CLI) lub polecenie Intlayer: extract content to Dictionary z rozszerzenia Intlayer VS Code (zobacz dokumentację rozszerzenia VS Code).
Użycie
Vite
Dla aplikacji opartych na Vite (React, Vue, Svelte itp.) najprostszym sposobem użycia kompilatora jest wtyczka vite-intlayer.
Instalacja
Skopiuj kod do schowka
npm install vite-intlayerKonfiguracja
Zaktualizuj swój plik vite.config.ts, aby dołączyć wtyczkę intlayerCompiler:
Skopiuj kod do schowka
import { defineConfig } from "vite";import { intlayer, intlayerCompiler } from "vite-intlayer";export default defineConfig({ plugins: [ intlayer(), intlayerCompiler(), // Dodaje wtyczkę kompilatora ],});See complete tutorial: Intlayer Compiler with Vite+React
Wsparcie dla frameworków
Wtyczka Vite automatycznie wykrywa i obsługuje różne typy plików:
- React / JSX / TSX: Obsługiwane natywnie.
- Vue: Wymaga
@intlayer/vue-compiler. - Svelte: Wymaga
@intlayer/svelte-compiler.
Upewnij się, że zainstalowałeś odpowiedni pakiet kompilatora dla swojego frameworka:
Skopiuj kod do schowka
# Dla Vuenpm install @intlayer/vue-compiler# Dla Sveltenpm install @intlayer/svelte-compilerWłasna konfiguracja
Aby dostosować zachowanie kompilatora, możesz zaktualizować plik intlayer.config.ts w katalogu głównym swojego projektu.
Skopiuj kod do schowka
import { type IntlayerConfig, Locales } from "intlayer";const config: IntlayerConfig = { compiler: { /** * Wskazuje, czy kompilator powinien być włączony. * Ustaw na 'build-only', aby pominąć kompilator podczas programowania i przyspieszyć czas uruchamiania. */ enabled: true, /** * Definiuje ścieżkę plików wyjściowych. Zastępuje `outputDir`. * * - Ścieżki zaczynające się od `./` są rozwiązywane względem katalogu komponentu. * - Ścieżki zaczynające się od `/` są rozwiązywane względem katalogu głównego projektu (`baseDir`). * * - Uwzględnienie zmiennej `{{locale}}` w ścieżce umożliwi generowanie słowników oddzielonych według języka. * * Przykłady: * ```ts * { * // Utwórz wielojęzyczne pliki .content.ts obok komponentu * output: ({ fileName, extension }) => `./${fileName}${extension}`, * * // output: './{{fileName}}{{extension}}', // Równoważne użycie szablonu ciągu znaków * } * ``` * * ```ts * { * // Utwórz scentralizowane pliki JSON według języka w katalogu głównym projektu * output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`, * * // output: '/locales/{{locale}}/{{key}}.content.json', // Równoważne użycie szablonu ciągu znaków * } * ``` * * Lista zmiennych: * - `fileName`: Nazwa pliku. * - `key`: Klucz zawartości. * - `locale`: Język zawartości. * - `extension`: Rozszerzenie pliku. * - `componentFileName`: Nazwa pliku komponentu. * - `componentExtension`: Rozszerzenie pliku komponentu. * - `format`: Format słownika. * - `componentFormat`: Format słownika komponentu. * - `componentDirPath`: Ścieżka do katalogu komponentu. */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Wskazuje, czy komponenty powinny być zapisywane po transformacji. * W ten sposób kompilator można uruchomić tylko raz, aby przetransformować aplikację, a następnie go usunąć. */ saveComponents: false, /** * Wstaw tylko zawartość do wygenerowanego pliku. Przydatne dla wyjścia JSON i18next lub ICU MessageFormat na język. * * - `output: ({ locale, key }) => `./locale/${locale}/${key}.json`,` */ noMetadata: false, /** * Prefiks klucza słownika */ dictionaryKeyPrefix: "", // Dodaj opcjonalny prefiks dla wyekstrahowanych kluczy słownika },};Odniesienie do konfiguracji kompilatora
Następujące właściwości można skonfigurować w bloku compiler pliku intlayer.config.ts:
enabled:
- Typ:
boolean | 'build-only' - Domyślny:
true - Opis: Wskazuje, czy kompilator powinien być włączony.
- Typ:
dictionaryKeyPrefix:
- Typ:
string - Domyślny:
'' - Opis: Prefiks dla wyekstrahowanych kluczy słownika.
- Typ:
transformPattern:
- Typ:
string | string[] - Domyślny:
['**/*.{js,ts,mjs,cjs,jsx,tsx,vue,svelte}', '!**/node_modules/**'] - Opis: (Zdeprecjonowane: użyj
build.traversePatternzamiast tego) Wzorce do przeszukiwania kodu w celu optymalizacji.
- Typ:
excludePattern:
- Typ:
string | string[] - Domyślny:
['**/node_modules/**'] - Opis: (Zdeprecjonowane: użyj
build.traversePatternzamiast tego) Wzorce do wykluczenia z optymalizacji.
- Typ:
output:
- Typ:
FilePathPattern - Domyślny:
({ key }) => 'compiler/${key}.content.json' - Opis: Definiuje ścieżkę plików wyjściowych. Zastępuje
outputDir. Obsługuje zmienne dynamiczne, takie jak{{locale}},{{key}},{{fileName}},{{extension}},{{format}},{{dirPath}},{{componentFileName}},{{componentExtension}},{{componentFormat}}. Można ustawić jako ciąg znaków w formacie'my/{{var}}/path'lub jako funkcję. - Uwaga: Ścieżki
./**/*są rozwiązywane względem komponentu. Ścieżki/**/*są rozwiązywane względembaseDirIntlayer. - Uwaga: Jeśli język jest zdefiniowany w ścieżce, słowniki będą generowane na język.
- Przykład:
output: ({ locale, key }) => 'compiler/${locale}/${key}.json'
- Typ:
noMetadata:
- Typ:
boolean - Domyślny:
false - Opis: Wskazuje, czy metadane powinny być zapisywane w pliku. Jeśli true, kompilator nie będzie zapisywał metadanych słowników (klucza, otoczki zawartości). Przydatne dla wyjść JSON i18next lub ICU MessageFormat na lokalizację.
- Uwaga: Przydatne w przypadku korzystania z wtyczki
loadJSON. - Przykład:
Jeśli
true:json { "key": "value" }Jeślifalse:json { "key": "value", "content": { "key": "value" } }
- Typ:
saveComponents:
- Typ:
boolean - Domyślny:
false - Opis: Wskazuje, czy komponenty powinny być zapisywane po transformacji.
- Typ:
Uzupełnij brakujące tłumaczenia
Intlayer udostępnia narzędzie CLI, które pomaga uzupełnić brakujące tłumaczenia. Możesz użyć polecenia intlayer, aby przetestować i uzupełnić brakujące tłumaczenia w swoim kodzie.
Skopiuj kod do schowka
npx intlayer test # Sprawdź, czy brakuje tłumaczeńSkopiuj kod do schowka
npx intlayer fill # Uzupełnij brakujące tłumaczeniaEkstrakcja
Intlayer udostępnia narzędzie CLI do wyodrębniania treści z Twojego kodu. Możesz użyć polecenia intlayer extract, aby wyodrębnić treść ze swojego kodu.
Skopiuj kod do schowka
npx intlayer extractWięcej szczegółów znajdziesz w dokumentacji CLI