TacoTranslate
/
DokumentasjonPrisar
 
  1. Innleiing
  2. Kom i gang
  3. Oppsett og konfigurasjon
  4. Bruke TacoTranslate
  5. Gjengiving på serversida
  6. Avansert bruk
  7. Beste praksisar
  8. Feilhandsaming og feilsøking
  9. Støtta språk

Beste praksisar

Legg URL-ar i variablar

Når du omset strengar som inneheld nettadresser eller liknande data, er det god praksis å plassere desse nettadressene i variablar og deretter referere til dei i malane dine.

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

Bruk ARIA-etikettar

Når du omset teksten i interaktive element som knappar, er det viktig å inkludere ARIA-etikettar for å sikre tilgjengelegheit. ARIA-etikettar hjelper skjermlesarar med å gi beskrivande informasjon om funksjonen til elementet.

Til dømes, dersom du har ein knapp som lar brukarar kopiere tekst frå ein kodeblokk, kan du bruke aria-label -attributtet for å gi ei tydeleg skildring:

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

Det er noko ved dette som kjennest veldig meta.

Globalt array med originar og fleire originar per komponent

Dette mønsteret verkar berre når du brukar Next.js Pages Router.

Når du arbeider med større applikasjonar, er det lurt å dele strengar og omsetjingar opp i fleire, mindre originar. Dette bidrar til å redusere pakkestørrelsar og overføringstider, og sikrar effektiv og skalerbar lokalisering.

Dette er enkelt når rendering berre skjer på klienten, men det å handsame originar blir raskt komplekst når du hentar omsetjingar for rendering på serversida. Du kan derimot automatisere handsaminga av originar ved å bruke TacoTranslate-klienten sin origins array.

Sjå dette dømet, der vi har delt komponentane og sidene våre opp i eigne filer.

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

Sjå våre døme på server-side rendering for meir informasjon om getTacoTranslateStaticProps.

Feilhandsaming og feilsøking

Eit produkt frå NattskiftetLaga i Noreg