Zadaj pytanie i otrzymaj streszczenie dokumentu, odwołując się do tej strony i wybranego dostawcy AI
Treść tej strony została przetłumaczona przy użyciu sztucznej inteligencji.
Zobacz ostatnią wersję oryginalnej treści w języku angielskimIf you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
Nowy Intlayer v7 - Co nowego?
Witamy w Intlayer v7! To duże wydanie wprowadza znaczące ulepszenia w wydajności, bezpieczeństwie typów oraz doświadczeniu deweloperskim. Poniżej znajdują się najważniejsze zmiany, wraz z notatkami migracyjnymi i praktycznymi przykładami.
Najważniejsze zmiany
- Strategia buforowania dla szybszych kompilacji
- Ulepszone generowanie typów TypeScript z typami specyficznymi dla lokalizacji
- Optymalizacja pakietu: lokalizacje jako łańcuchy znaków zamiast enumów
- Nowe tryby routingu:
prefix-no-default,prefix-all,no-prefix,search-params - Przechowywanie lokalizacji zgodne z RODO, domyślnie w localStorage
- Elastyczna konfiguracja przechowywania: cookies, localStorage, sessionStorage lub wiele jednocześnie
- Pakiet Visual Editor mniejszy o 30%
- Rozszerzone opcje konfiguracji middleware
- Zaktualizowane zachowanie polecenia fill dla lepszego zarządzania treścią
- Zwiększona stabilność dzięki pełnym aktualizacjom plików deklaracji treści
- Inteligentne zarządzanie ponownymi próbami dla dokładności tłumaczeń
- Równoległe przetwarzanie dla szybszej obsługi tłumaczeń
- Inteligentne dzielenie na fragmenty, aby obsłużyć duże pliki w ramach limitów kontekstu AI
Wydajność: Caching dla szybszych kompilacji
Zamiast przebudowywać deklaracje treści za pomocą esbuild przy każdym buildzie, wersja 7 wprowadza strategię cache’owania, która przyspiesza proces budowania.
Skopiuj kod do schowka
npx intlayer buildNowy system cache’owania:
- Przechowuje skompilowane deklaracje treści, aby uniknąć zbędnego przetwarzania
- Wykrywa zmiany i przebudowuje tylko zmodyfikowane pliki
- Znacząco skraca czas budowania dużych projektów
TypeScript: Generowanie typów specyficznych dla lokalizacji
Typy TypeScript są teraz generowane dla każdej lokalizacji osobno, co zapewnia silniejsze typowanie i eliminuje typy unii obejmujące wszystkie lokalizacje.
Zachowanie w wersji 6:
Skopiuj kod do schowka
const content = getIntlayer("my-title-content", "en");// typeof content = { title: "My title" } | { title: "Mon titre" } | { title: "Mi título" }Zachowanie w wersji 7:
Skopiuj kod do schowka
const content = getIntlayer("my-title-content", "en");// typeof content = { title: "My title" }Korzyści:
- Bardziej precyzyjne podpowiedzi w Twoim IDE
- Lepsze bezpieczeństwo typów bez zanieczyszczenia typów między lokalizacjami
- Poprawiona wydajność dzięki zmniejszeniu złożoności typów
Optymalizacja bundla: Lokalizacje jako stringi
Typ Locales nie jest już enumeracją, co oznacza, że jest teraz w pełni możliwy do tree-shakingu i nie będzie powiększał Twojego bundla o tysiące nieużywanych rekordów lokalizacji.
v6:
Skopiuj kod do schowka
import { Locales } from "intlayer";// Enum zawierający wszystkie lokalizacje -> nie jest możliwy do tree-shakinguconst locale: Locales = Locales.ENGLISH;v7:
Skopiuj kod do schowka
import { Locales, Locale } from "intlayer";// Typ string -> w pełni możliwy do tree-shakinguconst locale: Locale = Locales.ENGLISH;PonieważLocalesnie jest już enumeracją, będziesz musiał zmienić typ zLocalesnaLocale, aby uzyskać lokalizację jako typ.
Zobacz szczegóły implementacji po więcej informacji.
Nowe tryby routingu dla większej elastyczności
Wersja v7 wprowadza zunifikowaną konfigurację routing.mode, która zastępuje poprzednie opcje prefixDefault i noPrefix, oferując bardziej szczegółową kontrolę nad strukturą URL.
Dostępne tryby routingu
prefix-no-default(domyślny): Domyślna lokalizacja nie ma prefiksu, inne lokalizacje mają/dashboard(en) lub/fr/dashboard(fr)
prefix-all: Wszystkie lokalizacje mają prefiks/en/dashboard(en) lub/fr/dashboard(fr)
no-prefix: Brak prefiksów lokalizacji w URL (lokalizacja obsługiwana przez storage/headers)/dashboarddla wszystkich lokalizacji
search-params: Lokalizacja przekazywana jako parametr zapytania/dashboard?locale=enlub/dashboard?locale=fr
Podstawowa konfiguracja
Skopiuj kod do schowka
// intlayer.config.tsexport default { internationalization: { locales: ["en", "fr", "es"], defaultLocale: "en", }, routing: { mode: "prefix-no-default", // domyślnie },};Zgodność z RODO: storage w localStorage / cookies
Wersja v7 stawia na prywatność użytkownika, używając localStorage jako domyślnego mechanizmu przechowywania zamiast cookies. Ta zmiana pomaga w zgodności z RODO, unikając wymagań dotyczących zgody na cookies dla preferencji lokalizacji.
Opcje konfiguracji storage
Nowe pole routing.storage jest również dostępne oprócz wcześniejszych opcji middleware.cookieName i middleware.serverSetCookie, oferując elastyczne konfiguracje przechowywania:
Skopiuj kod do schowka
// Wyłącz przechowywaniestorage: false// Proste typy przechowywaniastorage: 'cookie'storage: 'localStorage'storage: 'sessionStorage'// Cookie z niestandardowymi atrybutamistorage: { type: 'cookie', name: 'custom-locale', domain: '.example.com', secure: true, sameSite: 'strict'}// localStorage z niestandardowym kluczemstorage: { type: 'localStorage', name: 'custom-locale'}// Wiele typów przechowywania dla redundancjistorage: ['cookie', 'localStorage']Przykład konfiguracji zgodnej z RODO
Dla aplikacji produkcyjnych, które muszą wyważyć funkcjonalność z zgodnością z RODO:
Skopiuj kod do schowka
// intlayer.config.tsexport default { internationalization: { locales: ["en", "fr", "es"], defaultLocale: "en", }, routing: { mode: "prefix-no-default", storage: [ { type: "localStorage", // Główne przechowywanie (nie wymaga zgody) name: "user-locale", }, { type: "cookie", // Opcjonalne przechowywanie w ciasteczkach (wymaga zgody) name: "user-locale", secure: true, sameSite: "strict", httpOnly: false, }, ], },};Włączanie / wyłączanie przechowywania w ciasteczkach
Przykład użycia w React / Next.js:
Można zdefiniować globalnie:
Skopiuj kod do schowka
<IntlayerProvider isCookieEnabled={false}> <App /></IntlayerProvider>Można nadpisać lokalnie dla każdego hooka:
Skopiuj kod do schowka
const { setLocale } = useLocale({ isCookieEnabled: false });setLocale("en");Uwaga: Cookies są domyślnie włączone. Uwaga: Sprawdź wymagania dotyczące plików cookie zgodne z RODO dla swojego konkretnego przypadku użycia.
Edytor wizualny: pakiet o 30% mniejszy
Pakiet Edytora wizualnego został zoptymalizowany i jest o 30% mniejszy niż poprzednia wersja, dzięki:
- Poprawie wydajności edytora kodu
- Usunięciu niepotrzebnych zależności od pakietów rdzenia Intlayer
- Lepszemu tree-shakingowi i bundlowaniu modułów
Skutkuje to szybszym czasem pobierania i lepszą wydajnością działania Twojej aplikacji.
Komenda fill: Zaktualizowane zachowanie dla lepszego zarządzania treścią
Wersja 7 wprowadza ulepszone zachowanie komendy fill, zapewniając bardziej przewidywalne i elastyczne zarządzanie treścią:
Nowe zachowanie polecenia fill
fill: true- Nadpisuje bieżący plik wypełnioną zawartością dla wszystkich lokalizacjifill: "ścieżka/do/pliku"- Wypełnia określony plik bez modyfikowania bieżącego plikufill: false- Całkowicie wyłącza automatyczne wypełnianie
Ulepszone wsparcie dla złożonych struktur zawartości
Polecenie fill obsługuje teraz złożone struktury deklaracji zawartości, w tym:
- Obiekty złożone: Deklaracje zawartości, które odwołują się do innych obiektów
- Zawartość destrukturyzowana: Zawartość wykorzystująca wzorce destrukturyzacji
- Zagnieżdżone odwołania: Obiekty wywołujące się nawzajem w złożonych hierarchiach
- Dynamiczne struktury zawartości: Zawartość z warunkowymi lub obliczanymi właściwościami
Korzyści
- Jasniejszy zamiar: Zachowanie jest teraz bardziej jednoznaczne co do tego, co jest modyfikowane
- Lepsze rozdzielenie: Pliki z zawartością mogą być przechowywane oddzielnie od wypełnionych tłumaczeń
- Ulepszony przepływ pracy: Deweloperzy mają większą kontrolę nad miejscem przechowywania tłumaczeń
- Wsparcie dla złożonych struktur: Obsługa zaawansowanych architektur zawartości z wieloma powiązanymi obiektami
Przykład użycia
Skopiuj kod do schowka
// Nadpisz bieżący plik wszystkimi lokalizacjamiconst content = { key: "example", fill: true, // Nadpisuje ten plik content: { title: "Hello World", },};// Wypełnij osobny plik bez modyfikacji bieżącego plikuconst content = { key: "example", fill: "./translations.json", // Tworzy/aktualizuje translations.json content: { title: "Hello World", },};// Wyłącz automatyczne wypełnianieconst content = { key: "example", fill: false, // Brak automatycznego wypełniania content: { title: "Hello World", },};// Złożona struktura treści z obiektami złożonymiconst sharedContent = { buttons: { save: "Zapisz", cancel: "Anuluj", },};const content = { key: "complex-example", fill: true, content: { // Odwołania do innych obiektów sharedContent, // Rozpakowana zawartość ...sharedContent, // Zagnieżdżone odwołania sections: [ { ...sharedContent.buttons, header: "Sekcja 1", }, ], },};Zwiększona stabilność i zarządzanie tłumaczeniami
Wersja 7 wprowadza kilka usprawnień, które czynią tłumaczenie treści bardziej niezawodnym i efektywnym:
Pełne aktualizacje plików deklaracji treści
System teraz aktualizuje pliki .content.{ts,js,cjs,mjs} zamiast częściowych aktualizacji, co zapewnia:
- Integralność danych: Pełne przepisywanie plików zapobiega częściowym aktualizacjom, które mogłyby uszkodzić zawartość
- Spójność: Wszystkie lokalizacje są aktualizowane atomowo, co utrzymuje synchronizację
- Niezawodność: Zmniejsza ryzyko niekompletnych lub uszkodzonych plików zawartości
Inteligentne zarządzanie ponownymi próbami
Nowe mechanizmy ponownych prób zapobiegają przesyłaniu zawartości w niepoprawnych formatach i unikają przerwania całego procesu wypełniania, jeśli jedno żądanie się nie powiedzie.
Równoległość dla szybszego przetwarzania
Operacje tłumaczenia są teraz wykonywane w kolejce, aby uruchamiać je równolegle. Znacząco przyspiesza to proces.
Inteligentne dzielenie na fragmenty dla dużych plików
Zaawansowane strategie dzielenia na fragmenty radzą sobie z dużymi plikami zawartości, nie przekraczając limitów kontekstu AI:
Przykładowy przebieg pracy
Skopiuj kod do schowka
// Duży plik zawartości jest automatycznie dzielony na fragmentyconst content = { key: "large-documentation", fill: true, content: { // Duża zawartość automatycznie dzielona na fragmenty do przetwarzania przez AI introduction: "..." // ponad 5000 znaków sections: [ // Wiele dużych sekcji ] }};System automatycznie:
- Analizuje rozmiar i strukturę zawartości
- Odpowiednio dzieli zawartość na fragmenty
- Przetwarza fragmenty równolegle
- Waliduje i ponawia próby w razie potrzeby
- Odtwarza kompletny plik
Notatki migracyjne z wersji v6
Usunięte konfiguracje
middleware.cookieName: Zastąpione przezrouting.storagemiddleware.serverSetCookie: Zastąpione przezrouting.storagemiddleware.prefixDefault: Zastąpione przezrouting.modemiddleware.noPrefix: Zastąpione przezrouting.mode
Mapowanie migracji
Mapowanie konfiguracji
Otwórz tabelę w oknie modalnym, aby wyraźnie zobaczyć całą zawartość
| Konfiguracja v6 | Konfiguracja v7 |
|---|---|
autoFill: xxx | fill: xxx |
prefixDefault: false | mode: 'prefix-no-default' |
prefixDefault: true | mode: 'prefix-all' |
noPrefix: true | mode: 'no-prefix' |
cookieName: 'my-locale' | storage: { type: 'cookie', name: 'my-locale' } |
serverSetCookie: 'never' | storage: false lub usuń cookie z tablicy storage` |
Przykład migracji
Przed (v6):
Skopiuj kod do schowka
export default { middleware: { headerName: "x-intlayer-locale", cookieName: "intlayer-locale", prefixDefault: false, basePath: "", serverSetCookie: "always", noPrefix: false, },};Po (v7):
Skopiuj kod do schowka
export default { routing: { mode: "prefix-no-default", storage: "localStorage", // lub 'cookie', jeśli potrzebujesz przechowywania w ciasteczkach headerName: "x-intlayer-locale", basePath: "", },};Mapowanie zawartości słownika
Otwórz tabelę w oknie modalnym, aby wyraźnie zobaczyć całą zawartość
| Zawartość słownika v6 | Zawartość słownika v7 |
|---|---|
autoFill: xxx | fill: xxx |
Przykład migracji
Przed (v6):
Skopiuj kod do schowka
const content = { key: "example", autoFill: true, // Nadpisuje ten plik content: { title: "Hello World", },};Po (v7):
Skopiuj kod do schowka
const content = { key: "example", fill: true, // Nadpisuje ten plik content: { title: "Hello World", },};Notatki dotyczące migracji z v5 do v6
Sprawdź notatki dotyczące migracji z v5 do v6 po więcej informacji.