TacoTranslate
/
Tài liệuBảng giá
 
Bài viết
04 thg 5

Giải pháp tốt nhất cho quốc tế hóa (i18n) trong các ứng dụng Next.js

Bạn có đang muốn mở rộng ứng dụng Next.js của mình đến các thị trường mới không? TacoTranslate giúp bạn dễ dàng bản địa hóa dự án Next.js, cho phép bạn tiếp cận đối tượng toàn cầu mà không gặp rắc rối.

Tại sao chọn TacoTranslate cho Next.js?

  • Tích hợp mượt mà: Được thiết kế đặc biệt cho các ứng dụng Next.js, TacoTranslate tích hợp dễ dàng vào quy trình làm việc hiện tại của bạn.
  • Tự động thu thập chuỗi: Không cần quản lý thủ công các tệp JSON nữa. TacoTranslate tự động thu thập các chuỗi từ mã nguồn của bạn.
  • Dịch thuật dựa trên AI: Tận dụng sức mạnh của AI để cung cấp các bản dịch chính xác theo ngữ cảnh, phù hợp với tông điệu của ứng dụng bạn.
  • Hỗ trợ ngôn ngữ tức thì: Thêm hỗ trợ cho các ngôn ngữ mới chỉ với một cú nhấp chuột, giúp ứng dụng của bạn có thể truy cập toàn cầu.

Cách nó hoạt động

Khi thế giới trở nên toàn cầu hóa hơn, việc các nhà phát triển web xây dựng ứng dụng có thể phục vụ người dùng từ nhiều quốc gia và văn hóa khác nhau ngày càng trở nên quan trọng. Một trong những cách chính để đạt được điều này là thông qua quốc tế hóa (i18n), cho phép bạn điều chỉnh ứng dụng của mình theo các ngôn ngữ, tiền tệ và định dạng ngày tháng khác nhau.

Trong hướng dẫn này, chúng ta sẽ khám phá cách thêm quốc tế hóa vào ứng dụng React Next.js của bạn, với khả năng kết xuất phía máy chủ. TL;DR: Xem ví dụ đầy đủ tại đây.

Hướng dẫn này dành cho các ứng dụng Next.js đang sử dụng Pages Router.
Nếu bạn đang sử dụng App Router, vui lòng xem hướng dẫn này.

Bước 1: Cài đặt thư viện i18n

Để triển khai quốc tế hóa trong ứng dụng Next.js của bạn, trước tiên chúng ta sẽ chọn một thư viện i18n. Có một số thư viện phổ biến, bao gồm next-intl. Tuy nhiên, trong ví dụ này, chúng ta sẽ sử dụng TacoTranslate.

TacoTranslate tự động dịch các chuỗi của bạn sang bất kỳ ngôn ngữ nào bằng công nghệ AI tiên tiến, và giải phóng bạn khỏi việc quản lý tẻ nhạt các tệp JSON.

Hãy cài đặt nó bằng cách sử dụng npm trong terminal của bạn:

npm install tacotranslate

Bước 2: Tạo tài khoản TacoTranslate miễn phí

Bây giờ bạn đã cài đặt xong module, đã đến lúc tạo tài khoản TacoTranslate của bạn, một dự án dịch thuật và các khóa API liên quan. Tạo tài khoản tại đây. Nó miễn phí, và không yêu cầu bạn phải thêm thẻ tín dụng.

Trong giao diện ứng dụng TacoTranslate, hãy tạo một dự án và chuyển đến tab khóa API của dự án đó. Tạo một khóa read và một khóa read/write. Chúng ta sẽ lưu chúng dưới dạng biến môi trường. Khóa read là cái mà chúng ta gọi là public và khóa read/writesecret. Ví dụ, bạn có thể thêm chúng vào một tệp .env ở thư mục gốc của dự án.

.env
TACOTRANSLATE_PUBLIC_API_KEY=123456
TACOTRANSLATE_SECRET_API_KEY=789010

Hãy đảm bảo không bao giờ làm lộ khóa API bí mật read/write ra môi trường sản xuất phía client.

Chúng tôi cũng sẽ thêm hai biến môi trường nữa: TACOTRANSLATE_DEFAULT_LOCALETACOTRANSLATE_ORIGIN.

  • TACOTRANSLATE_DEFAULT_LOCALE: Mã vùng ngôn ngữ dự phòng mặc định. Trong ví dụ này, chúng tôi sẽ đặt nó là en cho tiếng Anh.
  • TACOTRANSLATE_ORIGIN: “Thư mục” nơi các chuỗi của bạn sẽ được lưu trữ, chẳng hạn như URL của trang web bạn. Đọc thêm về origins tại đây.
.env
TACOTRANSLATE_DEFAULT_LOCALE=en
TACOTRANSLATE_ORIGIN=your-website-url.com

Bước 3: Thiết lập TacoTranslate

Để tích hợp TacoTranslate với ứng dụng của bạn, bạn sẽ cần tạo một client sử dụng các khóa API đã có trước đó. Ví dụ, tạo một file có tên /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;

Chúng tôi sẽ tự động định nghĩa TACOTRANSLATE_API_KEY trong thời gian ngắn.

Tạo client trong một file riêng biệt giúp dễ dàng sử dụng lại sau này. Bây giờ, sử dụng một /pages/_app.tsx tùy chỉnh, chúng ta sẽ thêm nhà cung cấp 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>
	);
}

Nếu bạn đã có pageProps_app.tsx tùy chỉnh, vui lòng mở rộng định nghĩa với các thuộc tính và mã từ phần trên.

Bước 4: Triển khai kết xuất phía máy chủ

TacoTranslate cho phép kết xuất phía máy chủ cho các bản dịch của bạn. Điều này cải thiện đáng kể trải nghiệm người dùng bằng cách hiển thị nội dung đã được dịch ngay lập tức, thay vì ban đầu có một flash nội dung chưa được dịch. Thêm vào đó, chúng ta có thể bỏ qua các yêu cầu mạng trên phía client, vì chúng ta đã có tất cả các bản dịch cần thiết.

Chúng ta sẽ bắt đầu bằng cách tạo mới hoặc sửa đổi /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'),
	});
};

Sửa đổi kiểm tra isProduction cho phù hợp với thiết lập của bạn. Nếu true, TacoTranslate sẽ hiển thị khóa API công khai. Nếu chúng ta đang ở trong môi trường cục bộ, thử nghiệm hoặc dàn dựng (isProduction is false), chúng ta sẽ sử dụng khóa API bí mật read/write để đảm bảo các chuỗi mới được gửi để dịch.

Cho đến nay, chúng tôi chỉ mới thiết lập ứng dụng Next.js với một danh sách các ngôn ngữ được hỗ trợ. Việc tiếp theo chúng ta sẽ làm là lấy bản dịch cho tất cả các trang của bạn. Để làm điều đó, bạn sẽ sử dụng hoặc getTacoTranslateStaticProps hoặc getTacoTranslateServerSideProps tùy theo yêu cầu của bạn.

Các hàm này nhận ba tham số: Một đối tượng Next.js Static Props Context, cấu hình cho TacoTranslate, và các thuộc tính tùy chọn của Next.js. Lưu ý rằng revalidate trên getTacoTranslateStaticProps được đặt mặc định là 60, để bản dịch của bạn luôn được cập nhật.

Để sử dụng một trong hai hàm này trong một trang, giả sử bạn có một tệp trang như /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!"/>;
}

Bây giờ bạn nên có thể sử dụng Translate component để dịch các chuỗi trong tất cả các component React của bạn.

import {Translate} from 'tacotranslate/react';

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

Bước 5: Triển khai và kiểm tra!

Chúng ta đã xong! Ứng dụng Next.js của bạn bây giờ sẽ tự động được dịch khi bạn thêm bất kỳ chuỗi nào vào Translate component. Lưu ý rằng chỉ có các môi trường có quyền read/write trên API key mới có thể tạo các chuỗi mới để dịch. Chúng tôi khuyến nghị bạn nên có một môi trường staging đóng và an toàn, nơi bạn có thể thử nghiệm ứng dụng sản xuất của mình với một API key như vậy, thêm các chuỗi mới trước khi đưa vào hoạt động. Điều này sẽ ngăn chặn bất kỳ ai ăn cắp API key bí mật của bạn và tiềm năng làm phình to dự án dịch thuật của bạn bằng cách thêm các chuỗi mới không liên quan.

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!

Một sản phẩm từ NattskiftetSản xuất tại Na Uy