en je zdrojová locale, ze které překládáte, a jakákoli locale ponechaná bez překladu se na ni automaticky vrátí.
Vaše aplikace má dva druhy přeložitelného textu a oba procházejí stejným
katalogem locales/:
- Popisky manifestu — názvy objektů a polí, názvy zobrazení, položky nabídky a další řetězce deklarované v metadatech vaší aplikace.
- Řetězce front komponent — text uživatelského rozhraní, který vykreslují vaše React front komponenty.
Označování řetězců front komponent
Importujte pomocné překladové funkce ztwenty-sdk/front-component:
Kdy co použít
<Trans>…</Trans>— statický text v JSX. Použijte propsmessageavaluespro interpolaci (<Trans message="Hi {name}" values={{ name }} />); interpolace přímo v potomcích není staticky extrahovatelná.useTranslate().t— dynamické řetězce uvnitř komponenty. Znovu se vykreslí, když uživatel přepne jazyk. Uvnitř renderu tomuto dávejte přednost.t(...)(importované přímo) — okamžitý překlad použitelný kdekoli, včetně obsluh událostí, pomocných funkcí a v modulovém rozsahu — nejen uvnitř renderu.msg(...)— líný deskriptor pro řetězce deklarované jako data (konstanty, konfigurace). Vyhodnoťte jej později pomocít(descriptor).
Kontext
Předejtecontext, abyste odlišili identické zdrojové řetězce, které se překládají
rozdílně:
Extrahování a překládání
Spusťte příkaz pro extrakci z adresáře své aplikace:t()/msg()/\<Trans>
z vašeho zdrojového kódu front komponent do locales/\<locale>.json, kde jsou klíčem
zdrojové řetězce. Doplňte překlady:
{name} jsou nahrazeny za běhu — ponechejte je v
překladu. Jakýkoli řetězec ponechaný prázdný spadne zpět na zdrojový text.
Jak to běží
twenty dev:build zkompiluje katalogy a doručí správný jazyk pro
aktuálního uživatele: popisky manifestu jsou vyhodnoceny na straně serveru a katalogy
front komponent jsou zabudovány do každého balíčku komponent. Za běhu komponenta čte
jazykovou verzi (locale) z vykonávacího kontextu (aktuální jazyk hostitele) a překládá
každý řetězec podle svého katalogu, přičemž při chybějícím překladu spadne zpět na zdroj. Přepnutí jazyka v hostiteli znovu vykreslí řetězce \<Trans> a
useTranslate().t v reálném čase.
Protože katalogy jsou kompilovány v době buildu, aktualizace překladu znamená
znovu spustit twenty dev:build (a znovu nasadit) stejně jako jakoukoli jinou změnu.
Překlady jsou kompilovány příkazy
twenty dev:build (a twenty apply). Nepřetržité sledování twenty dev zobrazuje zdrojové řetězce, takže lokalizovaný výstup
otestujte pomocí jednorázového buildu.<Trans> s textem mohou být rozloženi na více řádků — prázdné znaky jsou zpracovány
stejně, jako je zpracovává JSX, takže <Trans>Welcome\n back</Trans> i extrahovaný
klíč se oba stanou Welcome back.