Най-доброто решение за интернационализация (i18n) в приложенията на Next.js
Искате ли да разширите Next.js приложението си на нови пазари? TacoTranslate прави локализацията на вашия Next.js проект изключително лесна, позволявайки ви да достигнете глобална аудитория без усложнения.
Защо да изберете TacoTranslate за Next.js?
- Безпроблемна интеграция: Проектиран специално за приложения на Next.js, TacoTranslate лесно се интегрира във вашия съществуващ работен процес.
- Автоматично събиране на низове: Не е нужно повече ръчно да управлявате JSON файлове. TacoTranslate автоматично събира низове от вашата кодова база.
- Преводи, захранвани от ИИ: Използвайте мощта на ИИ, за да осигурите контекстно точни преводи, които съответстват на тона на вашето приложение.
- Незабавна поддръжка на езици: Добавете поддръжка за нови езици с едно щракване, за да направите приложението си достъпно за глобална аудитория.
Как работи
С нарастващата глобализация все по-важно за уеб разработчиците е да изграждат приложения, които могат да обслужват потребители от различни държави и култури. Един от ключовите начини да постигнете това е чрез интернационализация (i18n), която ви позволява да адаптирате приложението си към различни езици, валути и формати на датите.
В това ръководство ще разгледаме как да добавите интернационализация към вашето React Next.js приложение с рендериране от страна на сървъра. TL;DR: Вижте пълния пример тук.
Това ръководство е за приложения на Next.js, които използват Pages Router.
Ако използвате App Router, вместо това вижте това ръководство.
Стъпка 1: Инсталирайте библиотека за i18n
За да внедрите интернационализация във вашето приложение Next.js, първо ще изберем i18n библиотека. Има няколко популярни библиотеки, включително next-intl. Въпреки това, в този пример ще използваме TacoTranslate.
TacoTranslate автоматично превежда низовете ви на всеки език, използвайки най-съвременен ИИ, и ви освобождава от досадното управление на JSON файлове.
Нека го инсталираме с помощта на npm в терминала ви:
npm install tacotranslate
Стъпка 2: Създайте безплатен акаунт в TacoTranslate
Сега, когато сте инсталирали модула, е време да създадете вашия акаунт в TacoTranslate, проект за превод и свързаните с него API ключове. Създайте акаунт тук. Това е безплатно и не е необходимо да добавяте кредитна карта.
В интерфейса на приложението TacoTranslate създайте проект и отидете в раздела за API ключове. Създайте един read
ключ и един read/write
ключ. Ще ги запишем като променливи на средата. Ключът read
е това, което наричаме public
, а ключът read/write
е secret
. Например, можете да ги добавите във файл .env
в корена на вашия проект.
TACOTRANSLATE_PUBLIC_API_KEY=123456
TACOTRANSLATE_SECRET_API_KEY=789010
Уверете се, че никога не излагате секретния read/write
API ключ в клиентските продукционни среди.
Ще добавим още две променливи на средата: TACOTRANSLATE_DEFAULT_LOCALE
и TACOTRANSLATE_ORIGIN
.
TACOTRANSLATE_DEFAULT_LOCALE
: Кодът на локала, използван като резервна стойност по подразбиране. В този пример ще го зададем наen
за английски.TACOTRANSLATE_ORIGIN
: “папката”, в която ще се съхраняват вашите низове, например URL адресът на вашия уебсайт. Прочетете повече за origins тук.
TACOTRANSLATE_DEFAULT_LOCALE=en
TACOTRANSLATE_ORIGIN=your-website-url.com
Стъпка 3: Настройване на TacoTranslate
За да интегрирате TacoTranslate във вашето приложение, ще трябва да създадете клиент, използвайки API ключовете, споменати по-горе. Например, създайте файл с име /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;
Скоро ще дефинираме автоматично TACOTRANSLATE_API_KEY
.
Създаването на клиента в отделен файл улеснява повторното му използване по-късно. Сега, като използваме собствен /pages/_app.tsx
, ще добавим провайдъра 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>
);
}
Ако вече имате потребителски pageProps
и _app.tsx
, моля, разширете определението с горепосочените свойства и код.
Стъпка 4: Имплементиране на сървърно рендериране
TacoTranslate позволява сървърно рендиране на вашите преводи. Това значително подобрява потребителското изживяване, като показва преведено съдържание веднага, вместо първо да се появи проблясък на непреведено съдържание. Освен това можем да пропуснем мрежовите заявки на клиента, защото вече разполагаме с всички необходими преводи.
Ще започнем, като създадем или модифицираме /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'),
});
};
Променете проверката isProduction
така, че да отговаря на вашата настройка. Ако true
, TacoTranslate ще покаже публичния API ключ. Ако сме в локална, тестова или стейджинг среда (isProduction
is false
), ще използваме секретния read/write
API ключ, за да се уверим, че новите низове се изпращат за превод.
До момента сме настроили приложението Next.js само със списък на поддържаните езици. Следващото нещо, което ще направим, е да получим преводите за всички ваши страници. За да направите това, ще използвате или getTacoTranslateStaticProps
или getTacoTranslateServerSideProps
в зависимост от вашите изисквания.
Тези функции приемат три аргумента: един Next.js Static Props Context обект, конфигурация за TacoTranslate и незадължителни Next.js свойства. Обърнете внимание, че revalidate
на getTacoTranslateStaticProps
е зададено на 60 по подразбиране, така че вашите преводи да остават актуални.
За да използвате някоя от двете функции в страница, нека да приемем, че имате файл на страницата като /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!"/>;
}
Сега вече трябва да можете да използвате компонента Translate
за превеждане на низове във всички ваши React компоненти.
import {Translate} from 'tacotranslate/react';
function Component() {
return <Translate string="Hello, world!"/>
}
Стъпка 5: Разгрънете и тествайте!
Готово! Вашето Next.js приложение вече ще се превежда автоматично, когато добавите каквито и да е низове в Translate
компонент. Обърнете внимание, че само среди с разрешения read/write
за API ключа ще могат да създават нови низове за превод. Препоръчваме да имате затворена и защитена тестова среда, в която да тествате продукционното си приложение с такъв API ключ, като добавяте нови низове преди пускане на живо. Това ще попречи на някого да открадне вашия секретен API ключ и потенциално да раздуе вашия проект за преводи чрез добавяне на нови, несвързани низове.
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!