Cea mai bună soluție pentru internaționalizare (i18n) în aplicațiile Next.js
Dorești să îți extinzi aplicația Next.js pe piețe noi? TacoTranslate face incredibil de ușoară localizarea proiectului tău Next.js, permițându-ți să ajungi la un public global fără bătăi de cap.
De ce să alegi TacoTranslate pentru Next.js?
- Integrare perfectă: Conceput special pentru aplicațiile Next.js, TacoTranslate se integrează fără efort în fluxul tău de lucru existent.
- Colectare automată a șirurilor: Nu mai trebuie să gestionezi manual fișiere JSON. TacoTranslate colectează automat șirurile din codul tău.
- Traduceri bazate pe inteligență artificială: Profită de puterea inteligenței artificiale pentru a obține traduceri contextuale și precise, care se potrivesc tonului aplicației tale.
- Suport instantaneu pentru limbi: Adaugă suport pentru limbi noi cu doar un clic, făcând aplicația ta accesibilă la nivel global.
Cum funcționează
Pe măsură ce lumea devine tot mai globalizată, devine din ce în ce mai important ca dezvoltatorii web să construiască aplicații care să poată deservi utilizatori din diferite țări și culturi. Unul dintre modurile cheie de a realiza acest lucru este internaționalizarea (i18n), care vă permite să adaptați aplicația la limbi, valute și formate de dată diferite.
În acest tutorial, vom explora cum să adăugați internaționalizare aplicației dvs. React Next.js, folosind redare pe server. TL;DR: Consultați exemplul complet aici.
Acest ghid este pentru aplicațiile Next.js care folosesc Pages Router.
Dacă utilizați App Router, vă rugăm să consultați acest ghid.
Pasul 1: Instalează o bibliotecă i18n
Pentru a implementa internaționalizarea în aplicația dvs. Next.js, vom începe prin a alege o bibliotecă i18n. Există câteva biblioteci populare, inclusiv next-intl. Totuși, în acest exemplu, vom folosi TacoTranslate.
TacoTranslate traduce automat șirurile de caractere în orice limbă folosind inteligență artificială de ultimă generație și vă scapă de gestionarea obositoare a fișierelor JSON.
Să o instalăm folosind npm în terminalul dvs.:
npm install tacotranslatePasul 2: Creați un cont gratuit TacoTranslate
Acum că ai instalat modulul, este timpul să îți creezi contul TacoTranslate, un proiect de traducere și cheile API asociate. Creează-ți un cont aici. Este gratuit și nu necesită introducerea unui card de credit.
În interfața aplicației TacoTranslate, creează un proiect și navighează la fila cu chei API. Create one read key, and one read/write key. Le vom salva ca variabile de mediu. Cheia read este ceea ce numim public iar cheia read/write este secret. De exemplu, le poți adăuga într-un fișier .env aflat în rădăcina proiectului tău.
TACOTRANSLATE_PUBLIC_API_KEY=123456
TACOTRANSLATE_SECRET_API_KEY=789010Asigurați-vă că nu divulgați niciodată cheia API secretă read/write în mediile de producție pe partea clientului.
Vom adăuga, de asemenea, două variabile de mediu în plus: TACOTRANSLATE_DEFAULT_LOCALE și TACOTRANSLATE_ORIGIN.
TACOTRANSLATE_DEFAULT_LOCALE: Codul implicit al localizării de rezervă. În acest exemplu, îl vom seta laenpentru engleză.TACOTRANSLATE_ORIGIN: “folderul” în care vor fi stocate textele tale, cum ar fi URL‑ul site-ului tău. Citește mai multe despre origini aici.
TACOTRANSLATE_DEFAULT_LOCALE=en
TACOTRANSLATE_ORIGIN=your-website-url.comPasul 3: Configurarea TacoTranslate
Pentru a integra TacoTranslate în aplicația dvs., va trebui să creați un client folosind cheile API menționate mai devreme. De exemplu, creați un fișier numit /tacotranslate-client.js.
const {default: createTacoTranslateClient} = require('tacotranslate');
const tacoTranslate = createTacoTranslateClient({
apiKey:
process.env.TACOTRANSLATE_SECRET_API_KEY ??
process.env.TACOTRANSLATE_PUBLIC_API_KEY ??
process.env.TACOTRANSLATE_API_KEY ??
'',
projectLocale: process.env.TACOTRANSLATE_DEFAULT_LOCALE ?? '',
});
module.exports = tacoTranslate;Vom defini automat TACOTRANSLATE_API_KEY în curând.
Crearea clientului într-un fișier separat face mai ușoară reutilizarea lui ulterior. Acum, folosind un fișier personalizat /pages/_app.tsx, vom adăuga providerul TacoTranslate.
import React from 'react';
import {type AppProps} from 'next/app';
import {type Origin, type Locale, type Localizations} from 'tacotranslate';
import TacoTranslate from 'tacotranslate/react';
import TacoTranslateHead from 'tacotranslate/next/head';
import tacoTranslate from '../tacotranslate-client';
type PageProperties = {
origin: Origin;
locale: Locale;
locales: Locale[];
localizations: Localizations;
};
export default function App({Component, pageProps}: AppProps<PageProperties>) {
const {origin, locale, locales, localizations} = pageProps;
return (
<TacoTranslate
client={tacoTranslate}
origin={origin}
locale={locale}
localizations={localizations}
>
<TacoTranslateHead rootUrl="https://your-website.com" locales={locales} />
<Component {...pageProps} />
</TacoTranslate>
);
}Dacă aveți deja pageProps și _app.tsx personalizate, vă rugăm să extindeți definiția cu proprietățile și codul de mai sus.
Pasul 4: Implementarea redării pe server
TacoTranslate permite randarea pe server a traducerilor tale. Aceasta îmbunătățește considerabil experiența utilizatorului, afișând imediat conținutul tradus, în loc să apară întâi un scurt moment de conținut netradus. În plus, putem evita cererile de rețea din partea clientului, deoarece avem deja toate traducerile de care avem nevoie.
Vom începe prin a crea sau modifica /next.config.js.
const withTacoTranslate = require('tacotranslate/next/config').default;
const tacoTranslateClient = require('./tacotranslate-client');
module.exports = async () => {
const config = {};
return withTacoTranslate(config, {
client: tacoTranslateClient,
isProduction:
process.env.TACOTRANSLATE_ENV === 'production' ||
process.env.VERCEL_ENV === 'production' ||
(!(process.env.TACOTRANSLATE_ENV || process.env.VERCEL_ENV) &&
process.env.NODE_ENV === 'production'),
});
};Modifică verificarea isProduction pentru a se potrivi configurației tale. Dacă true, TacoTranslate va expune cheia publică a API-ului. Dacă ne aflăm într-un mediu local, de testare sau de staging (isProduction is false), vom folosi cheia secretă read/write a API-ului pentru a ne asigura că noile șiruri sunt trimise pentru traducere.
Până acum, am configurat aplicația Next.js doar cu o listă de limbi acceptate. Următorul lucru pe care îl vom face este să preluăm traducerile pentru toate paginile tale. Pentru aceasta, vei folosi fie getTacoTranslateStaticProps, fie getTacoTranslateServerSideProps în funcție de cerințele tale.
Aceste funcții primesc trei argumente: un obiect Next.js Static Props Context, configurația pentru TacoTranslate și proprietăți opționale Next.js. Rețineți că revalidate pe getTacoTranslateStaticProps este setat la 60 implicit, astfel încât traducerile dvs. să rămână actualizate.
Pentru a folosi oricare dintre funcții într-o pagină, să presupunem că aveți un fișier de pagină precum /pages/hello-world.tsx.
import {Translate} from 'tacotranslate/react';
import getTacoTranslateStaticProps from 'tacotranslate/next/get-static-props';
import tacoTranslateClient from '../tacotranslate-client';
export async function getStaticProps(context) {
return getTacoTranslateStaticProps(context, {client: tacoTranslateClient});
}
export default function Page() {
return <Translate string="Hello, world!"/>;
}Ar trebui să poți folosi acum componenta Translate pentru a traduce șirurile din toate componentele tale React.
import {Translate} from 'tacotranslate/react';
function Component() {
return <Translate string="Hello, world!"/>
}Pasul 5: Implementați și testați!
Am terminat! Aplicația dvs. Next.js va fi acum tradusă automat când adăugați orice texte într-o componentă Translate. Rețineți că numai mediile care au permisiuni read/write pentru cheia API vor putea crea noi șiruri care să fie traduse. Recomandăm să aveți un mediu de staging închis și securizat în care să vă testați aplicația de producție cu o astfel de cheie API, adăugând noi șiruri înainte de lansare. Astfel veți împiedica pe oricine să vă fure cheia API secretă și, eventual, să umfle proiectul de traduceri prin adăugarea de noi șiruri neconexe.
Be sure to check out the complete example over at our GitHub profile. There, you’ll also find an example of how to do this using the App Router! If you encounter any problems, feel free to reach out, and we’ll be more than happy to help.
TacoTranslate lets you automatically localize your React applications quickly to and from over 75 languages. Get started today!