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 애플리케이션 UI에서 프로젝트를 생성한 다음 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과 같습니다. 여기에서 origins에 대해 자세히 읽어보세요.
.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 애플리케이션에 지원되는 언어 목록만 설정했습니다. 다음으로 할 일은 모든 페이지의 번역을 가져오는 것입니다. 이를 위해 요구사항에 따라 getTacoTranslateStaticProps 또는 getTacoTranslateServerSideProps 중 하나를 사용하십시오.

이 함수들은 세 가지 인수를 받습니다: 하나의 Next.js Static Props Context 객체, TacoTranslate 구성, 그리고 선택적인 Next.js 속성들. 참고로 getTacoTranslateStaticPropsrevalidate는 기본적으로 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단계: 배포 및 테스트!

완료되었습니다! 이제 Next.js 애플리케이션은 Translate 컴포넌트에 문자열을 추가하면 자동으로 번역됩니다. 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에서 제공하는 제품노르웨이산