TacoTranslate
/
SənədləşdirməQiymətləndirmə
 
  1. Giriş
  2. Başlanğıc
  3. Quraşdırma və konfiqurasiya
  4. TacoTranslate-dən istifadə etmək
  5. Server tərəfi renderlənməsi
  6. Təkmil istifadə
  7. Ən yaxşı təcrübələr
  8. Səhv idarəetməsi və ayıklama
  9. Dəstəklənən dillər

Ən yaxşı təcrübələr

URL-ləri dəyişənlərə yerləşdirin

URL-lər və ya oxşar məlumatlar ehtiva edən sətirləri tərcümə edərkən, bu URL-ləri dəyişənlər daxilində yerləşdirmək və sonra şablonlarınızda onlara istinad etmək yaxşı təcrübə kimi qəbul edilir.

<Translate
	string={`Click <a href="{{url}}">here</a>`}
	variables={{url: 'https://tacotranslate.com'}}
/>

ARIA etiketlərindən istifadə edin

İnteraktiv elementlərin, məsələn, düymələrin mətnini tərcümə edərkən, əlçatanlığı təmin etmək üçün ARIA etiketlərini daxil etmək vacibdir. ARIA etiketləri ekran oxuyucularına elementin funksiyası haqqında təsviri məlumat verməyə kömək edir.

Məsələn, əgər istifadəçilərə kod blokundan mətn kopyalamağa imkan verən bir düyməniz varsa, aydın təsvir vermək üçün aria-label atributundan istifadə edə bilərsiniz:

<Translate
	aria-label={useTranslation('Copy to clipboard')}
	string="Copy"
/>

Bununla bağlı nəsə çox meta hiss edir.

Qlobal mənbələr massiv və çoxsaylı komponent mənbələri

Bu model yalnız Next.js Pages Router istifadə olunarkən işləyir.

Daha böyük tətbiqlərlə işləyərkən, mətnlər və tərcümələri bir neçə, daha kiçik origins hissələrinə bölmək faydalı olur. Bu yanaşma paket ölçülərini və ötürmə vaxtlarını azaldaraq səmərəli və miqyaslana bilən lokallaşmanı təmin edir.

Bu, yalnız müştəri tərəfində render edilərkən sadədir, amma server tərəfində render üçün tərcümələr əldə edilərkən origins idarəetməsi tez bir zamanda mürəkkəbləşir. Bununla belə, TacoTranslate müştəri origins massivindən istifadə edərək origins idarəetməsini avtomatlaşdıra bilərsiniz.

Bu nümunəyə baxın, burada komponentlərimizi və səhifələrimizi ayrı fayllara bölmüşük.

components/pricing-table.tsx
import TacoTranslate, {Translate} from 'tacotranslate/react';
import tacoTranslate from '../tacotranslate-client';

// Set an origin name for this component
const origin = 'components/pricing-table';

// Push the origin into the origins array as this file is imported
tacoTranslate.origins.push(origin);

export default function PricingTable() {
	return (
		<TacoTranslate origin={origin}>
			<Translate string="Pricing table" />
			// ...
		</TacoTranslate>
	);
}
pages/pricing.tsx
import TacoTranslate, {Translate} from 'tacotranslate/react';
import getTacoTranslateStaticProps from 'tacotranslate/next/get-static-props';
import tacoTranslateClient from '../tacotranslate-client';
import PricingTable from '../components/pricing-table';

const origin = 'pages/pricing';
tacoTranslateClient.origins.push(origin);

export default function PricingPage() {
	return (
		<TacoTranslate origin={origin}>
			<Translate string="Pricing page" />
			<PricingTable />
		</TacoTranslate>
	);
}

// We will now fetch translations for all imported components and their origins automatically
export async function getStaticProps(context) {
	return getTacoTranslateStaticProps(context, {client: tacoTranslateClient});
}

Daha ətraflı məlumat üçün getTacoTranslateStaticProps barədə server tərəfli render nümunələrimizi baxın.

Səhv idarəetməsi və ayıklama

Bir məhsul Nattskiftet-dənNorveçdə hazırlanmışdır