TacoTranslate
/
文档定价
 
5月04日

适用于 Next.js 应用的最佳国际化(i18n)解决方案

您是否希望将您的 Next.js 应用扩展到新市场?TacoTranslate 使本地化您的 Next.js 项目变得非常简单,帮助您无烦恼地触达全球受众。

为什么为 Next.js 选择 TacoTranslate?

  • 无缝集成:专为 Next.js 应用设计,TacoTranslate 能无缝融入您现有的工作流程。
  • 自动字符串收集:不再需要手动维护 JSON 文件。TacoTranslate 会自动从代码库中收集字符串。
  • AI 驱动的翻译:利用 AI 的能力,提供符合上下文且契合应用语气的精准翻译。
  • 即时语言支持:只需点击即可添加新语言支持,让您的应用面向全球用户。

工作原理

随着世界日益全球化,网络开发者构建能够满足不同国家和文化用户需求的应用变得越来越重要。实现这一目标的关键方法之一是国际化(i18n),它允许您将应用适配不同的语言、货币和日期格式。

在本教程中,我们将探讨如何为您的 React Next.js 应用添加国际化支持,并实现服务器端渲染。 TL;DR: 在这里查看完整示例。

本指南适用于使用 Pages Router 的 Next.js 应用。
如果您使用 App Router,请参阅此指南。

第 1 步: 安装一个 i18n 库

要在你的 Next.js 应用中实现国际化,首先我们会选择一个 i18n 库。有几个流行的库,包括 next-intl. 但是,在本示例中,我们将使用 TacoTranslate.

TacoTranslate 使用最先进的 AI 自动将你的字符串翻译成任意语言,并让你摆脱繁琐的 JSON 文件管理。

让我们在终端中使用 npm 来安装它:

npm install tacotranslate

第2步: 创建一个免费的 TacoTranslate 账户

现在您已经安装了该模块,是时候创建您的 TacoTranslate 账户、一个翻译项目以及相关的 API 密钥了。在这里创建账户。 这是免费的,并且 不需要您提供信用卡信息。

在 TacoTranslate 应用的界面中,创建一个项目,然后进入其 API 密钥选项卡。创建一个 read 密钥和一个 read/write 密钥。我们会将它们保存为环境变量。read 密钥就是我们所称的 public,而 read/write 密钥则是 secret。例如,你可以将它们添加到项目根目录下的 .env 文件中。

.env
TACOTRANSLATE_PUBLIC_API_KEY=123456
TACOTRANSLATE_SECRET_API_KEY=789010

请务必不要将秘密 read/write API 密钥泄露到客户端的生产环境中。

我们还将添加另外两个环境变量: TACOTRANSLATE_DEFAULT_LOCALETACOTRANSLATE_ORIGIN

  • TACOTRANSLATE_DEFAULT_LOCALE: 默认回退语言代码。在本示例中,我们将其设置为 en(英语)。
  • TACOTRANSLATE_ORIGIN: 存放字符串的“文件夹”,例如您网站的 URL。 在此了解有关来源的更多信息。
.env
TACOTRANSLATE_DEFAULT_LOCALE=en
TACOTRANSLATE_ORIGIN=your-website-url.com

第3步: 设置 TacoTranslate

要将 TacoTranslate 集成到您的应用程序中,您需要使用前面提供的 API 密钥创建一个客户端。例如,创建一个名为 /tacotranslate-client.js 的文件。

/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 提供者。

/pages/_app.tsx
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 开始。

/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 应用中设置了支持的语言列表。接下来我们要为你的所有页面获取翻译。为此,你可以根据需求使用 getTacoTranslateStaticPropsgetTacoTranslateServerSideProps

这些函数接受三个参数:一个 Next.js Static Props Context 对象,TacoTranslate 的配置,以及可选的 Next.js 属性。请注意,revalidategetTacoTranslateStaticProps 上的默认值为 60,这样你的翻译就能保持最新状态。

要在页面中使用任一函数,假设你有一个像 /pages/hello-world.tsx 这样的页面文件。

/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!"/>;
}

现在您应该可以在所有的 React 组件中使用 Translate 组件来翻译字符串。

import {Translate} from 'tacotranslate/react';

function Component() {
	return <Translate string="Hello, world!"/>
}

第5步: 部署并测试!

我们完成了!当你将任何字符串添加到 Translate 组件时,你的 Next.js 应用将会自动被翻译。请注意,只有在 API 密钥上具有 read/write 权限的环境才能创建要翻译的新字符串。我们建议拥有一个封闭且安全的预发布环境,在那里你可以使用这样的 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!

Nattskiftet 提供的产品挪威制造