TacoTranslate
/
DokumentasiHarga
 
  1. Pendahuluan
  2. Memulai
  3. Penyiapan dan konfigurasi
  4. Menggunakan TacoTranslate
  5. Perenderan sisi server
  6. Penggunaan Lanjutan
  7. Praktik terbaik
  8. Penanganan kesalahan dan debugging
  9. Bahasa yang didukung

Penggunaan Lanjutan

Menangani bahasa kanan-ke-kiri

TacoTranslate memudahkan dukungan bahasa yang ditulis dari kanan ke kiri (RTL), seperti bahasa Arab dan Ibrani, dalam aplikasi React Anda. Penanganan yang tepat terhadap bahasa RTL memastikan konten Anda ditampilkan dengan benar bagi pengguna yang membaca dari kanan ke kiri.

import {useTacoTranslate} from 'tacotranslate/react';

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

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

Anda juga dapat menggunakan fungsi isRightToLeftLocaleCode yang disediakan untuk memeriksa bahasa saat ini di luar React.

import {isRightToLeftLocaleCode} from 'tacotranslate';

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

Menonaktifkan terjemahan

Untuk menonaktifkan penerjemahan pada bagian tertentu dari sebuah string atau untuk memastikan segmen-segmen tertentu dipertahankan apa adanya, Anda dapat menggunakan tiga tanda kurung siku. Fitur ini berguna untuk menjaga format asli nama, istilah teknis, atau konten lain yang tidak boleh diterjemahkan.

import {Translate} from 'tacotranslate/react';

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

Dalam contoh ini, kata “TacoTranslate” akan tetap tidak berubah dalam terjemahan.

Beberapa penyedia TacoTranslate

Kami sangat mendorong penggunaan beberapa penyedia TacoTranslate dalam aplikasi Anda. Ini berguna untuk mengatur terjemahan dan string Anda ke dalam origin yang berbeda, seperti header, footer, atau bagian tertentu.

Anda dapat mempelajari lebih lanjut tentang penggunaan origins di sini.

Penyedia TacoTranslate mewarisi pengaturan dari penyedia induk mana pun, sehingga Anda tidak perlu mengulangi pengaturan lainnya.

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>
	);
}

Menimpa origin atau locale

Selain menggunakan beberapa penyedia TacoTranslate, Anda juga dapat menimpa baik origin maupun locale pada level komponen Translate dan hook useTranslation.

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

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

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

Menangani pemuatan

Ketika mengubah bahasa di sisi klien, pengambilan terjemahan mungkin memerlukan beberapa saat tergantung pada koneksi pengguna. Anda dapat menampilkan indikator pemuatan untuk meningkatkan pengalaman pengguna dengan memberikan umpan balik visual selama proses penggantian.

import {useTacoTranslate} from 'tacotranslate/react';

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

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

Pluralisasi

Untuk menangani pluralisasi dan menampilkan label berbasis jumlah dengan benar dalam berbagai bahasa, praktik terbaik adalah sebagai berikut:

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)}}
		/>
	);
}

Beberapa bahasa

Untuk mendukung beberapa bahasa secara bersamaan dalam aplikasi yang sama, Anda dapat menggunakan beberapa penyedia TacoTranslate dengan nilai locale yang berbeda seperti yang ditunjukkan di bawah ini:

Anda juga dapat menimpa locale pada tingkat komponen atau hook.

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>
	);
}

Menggunakan ID terjemahan

Anda dapat menambahkan id ke komponen Translate untuk menangani terjemahan atau makna yang berbeda untuk string yang sama. Ini sangat berguna ketika teks yang sama memerlukan terjemahan yang berbeda berdasarkan konteks. Dengan memberikan ID unik, Anda memastikan bahwa setiap kemunculan string diterjemahkan secara akurat sesuai makna spesifiknya.

import {Translate} from 'tacotranslate/react';

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

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

Misalnya, login pada header mungkin diterjemahkan menjadi “Iniciar sesión”, dan login pada footer mungkin diterjemahkan menjadi “Acceder” dalam bahasa Spanyol.

Praktik terbaik

Sebuah produk dari NattskiftetDibuat di Norwegia