TacoTranslate
/
DokumentationPreise
 
  1. Einführung
  2. Erste Schritte
  3. Einrichtung und Konfiguration
  4. TacoTranslate verwenden
  5. Serverseitiges Rendering
  6. Erweiterte Nutzung
  7. Bewährte Verfahren
  8. Fehlerbehandlung und Debugging
  9. Unterstützte Sprachen

Erweiterte Nutzung

Umgang mit rechts-nach-links-Sprachen

TacoTranslate erleichtert die Unterstützung von Sprachen, die von rechts nach links (RTL) geschrieben werden, wie Arabisch und Hebräisch, in Ihren React-Anwendungen. Eine korrekte Handhabung von RTL-Sprachen sorgt dafür, dass Ihre Inhalte für Nutzer, die von rechts nach links lesen, richtig angezeigt werden.

import {useTacoTranslate} from 'tacotranslate/react';

function Document() {
	const {locale, isRightToLeft} = useTacoTranslate();

	return (
		<html lang={locale} dir={isRightToLeft ? 'rtl' : 'ltr'}>
			<body>
				// ...
			</body>
		</html>
	);
}

Sie können auch die bereitgestellte isRightToLeftLocaleCode Funktion verwenden, um die aktuelle Sprache außerhalb von React zu überprüfen.

import {isRightToLeftLocaleCode} from 'tacotranslate';

function foo(locale = 'es') {
	const direction = isRightToLeftLocaleCode(locale) ? 'rtl' : 'ltr';
	// ...
}

Übersetzungen deaktivieren

Um die Übersetzung bestimmter Teile eines Strings zu deaktivieren oder sicherzustellen, dass bestimmte Segmente unverändert bleiben, können Sie dreifache eckige Klammern verwenden. Diese Funktion ist nützlich, um das ursprüngliche Format von Namen, Fachbegriffen oder anderen Inhalten beizubehalten, die nicht übersetzt werden sollen.

import {Translate} from 'tacotranslate/react';

function Component() {
	return (
		<Translate string="Hello, [[[TacoTranslate]]]!" />
	);
}

In diesem Beispiel bleibt das Wort „TacoTranslate“ in der Übersetzung unverändert.

Mehrere TacoTranslate-Anbieter

Wir empfehlen dringend, mehrere TacoTranslate Provider in Ihrer App zu verwenden. Dies ist nützlich, um Ihre Übersetzungen und Strings in verschiedene Origins zu strukturieren, z. B. für Ihren Header, Footer oder bestimmte Abschnitte.

Sie können hier mehr darüber lesen, wie Sie Origins verwenden.

TacoTranslate Provider erben Einstellungen von jedem übergeordneten Provider, sodass Sie keine weiteren Einstellungen wiederholen müssen.

import createTacoTranslateClient from 'tacotranslate';
import {TacoTranslate} from 'tacotranslate/react';

const tacoTranslateClient = createTacoTranslateClient({apiKey: 'YOUR_API_KEY'});

function Header() {
	return (
		<TacoTranslate origin="header">
			// ...
		</TacoTranslate>
	);
}

function Menu() {
	return (
		<TacoTranslate origin="menu">
			// ...
		</TacoTranslate>
	);
}

export default function App() {
	return (
		<TacoTranslate client={tacoTranslateClient} origin="page" locale="es">
			<Header />
			<Menu />
		</TacoTranslate>
	);
}

Origin oder Gebietsschema überschreiben

Zusätzlich zur Verwendung mehrerer TacoTranslate Provider können Sie sowohl Origin als auch Locale auf der Ebene der Translate Komponente und des useTranslation Hooks überschreiben.

import {Translate, useTranslation} from 'tacotranslate/react';

function Greeting() {
	const spanishHello = useTranslation('Hello!', {locale: 'es'});

	return (
		<>
			{spanishHello}
			<Translate string="What’s up?" origin="greeting" />
		</>
	);
}

Umgang mit Ladezuständen

Beim Wechsel der Sprache auf der Client-Seite kann das Laden der Übersetzungen je nach Verbindung des Benutzers einige Augenblicke dauern. Sie können einen Ladeindikator anzeigen, um während des Wechsels visuelles Feedback zu geben und so die Benutzererfahrung zu verbessern.

import {useTacoTranslate} from 'tacotranslate/react';

function Component() {
	const {isLoading} = useTacoTranslate();

	return (
		isLoading ? 'Translations are loading...' : null
	);
}

Pluralisierung

Um Pluralformen zu handhaben und zahlenabhängige Bezeichnungen in verschiedenen Sprachen korrekt anzuzeigen, gilt dies als bewährte Vorgehensweise:

import {Translate, useLocale} from 'tacotranslate/react';

function PhotoCount() {
	const locale = useLocale();
	const count = 1;

	return count === 0 ? (
		<Translate string="You have no photos." />
	) : count === 1 ? (
		<Translate string="You have 1 photo." />
	) : (
		<Translate
			string="You have {{count}} photos."
			variables={{count: count.toLocaleString(locale)}}
		/>
	);
}

Mehrere Sprachen

Um mehrere Sprachen gleichzeitig innerhalb derselben Anwendung zu unterstützen, können Sie mehrere TacoTranslate-Provider verwenden mit unterschiedlichen locale Werten, wie unten gezeigt:

Sie können locale auch auf Komponenten- oder Hook-Ebene überschreiben.

import createTacoTranslateClient from 'tacotranslate';
import {TacoTranslate, Translate} from 'tacotranslate/react';

const tacoTranslateClient = createTacoTranslateClient({apiKey: 'YOUR_API_KEY'});

function Spanish() {
	return (
		<TacoTranslate locale="es">
			<Translate string="Hello, world in Spanish!" />
		</TacoTranslate>
	);
}

function Norwegian() {
	return (
		<TacoTranslate locale="no">
			<Translate string="Hello, world in Norwegian!" />
		</TacoTranslate>
	);
}

export default function App() {
	return (
		<TacoTranslate client={tacoTranslateClient} origin="page" locale="es">
			<Spanish />
			<Norwegian />
		</TacoTranslate>
	);
}

Verwendung von Übersetzungs-IDs

Sie können der Translate Komponente ein id hinzufügen, um verschiedene Übersetzungen oder Bedeutungen für denselben String zu behandeln. Dies ist besonders nützlich, wenn derselbe Text je nach Kontext unterschiedliche Übersetzungen erfordert. Durch die Vergabe eindeutiger IDs stellen Sie sicher, dass jede Instanz des Strings entsprechend ihrer spezifischen Bedeutung genau übersetzt wird.

import {Translate} from 'tacotranslate/react';

function Header() {
	return (
		<Translate id="header" string="Login" />
	);
}

function Footer() {
	return (
		<Translate id="footer" string="Login" />
	);
}

Zum Beispiel könnte die Anmeldung im Header auf Spanisch als „Iniciar sesión“ und die Anmeldung im Footer als „Acceder“ übersetzt werden.

Bewährte Verfahren

Ein Produkt von NattskiftetHergestellt in Norwegen