Ən yaxşı təcrübələr
URL-ləri dəyişənlərdə saxlayın
URL-ləri və ya oxşar məlumatları ehtiva edən sətrləri tərcümə edərkən, bu URL-ləri dəyişənlər daxilində yerləşdirmək və sonra onlara şablonlarınızda istinad etmək yaxşı təcrübə hesab olunur.
<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 əlavə 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, istifadəçilərə kod blokundan mətn kopyalamağa imkan verən bir düyməniz varsa, aydın təsviri təmin etmək üçün aria-label
atributundan istifadə edə bilərsiniz:
<Translate
aria-label={useTranslation('Copy to clipboard')}
string="Copy"
/>
Bu barədə nəsə çox meta təsiri yaradır.
Qlobal başlanğıc massiv və çoxsaylı komponent başlanğıcları
Bu nümunə yalnız Next.js Pages Router istifadə edildikdə işləyir.
Daha böyük tətbiqlərlə işləyərkən, sətirləri və tərcümələri bir neçə kiçik mənbəyə bölmək faydalıdır. Bu yanaşma paket ölçülərini və ötürmə vaxtlarını azaldır, effektiv və miqyaslana bilən lokalizasiyanı təmin edir.
Bu, yalnız müştəri tərəfdə render edərkən sadə olsa da, server tərəfdə render üçün tərcümələri əldə edərkən mənbələrin idarə edilməsi sürətlə mürəkkəbləşir. Lakin, TacoTranslate müştəri origins
massivindən istifadə edərək mənbələrin idarəsini avtomatlaşdıra bilərsiniz.
Komponentlərimizi və səhifələrimizi ayrı fayllara ayırdığımız bu nümunəyə baxın.
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>
);
}
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
haqqında server-tərəfi render nümunələrimizi baxın.