이 레시피에서는 콘텐츠 컬렉션과 동적 라우팅을 사용하여 자체 국제화 (i18n) 솔루션을 구축하고 콘텐츠를 다양한 언어로 제공하는 방법을 배웁니다.
이 예시는 자체 하위 경로에서 각 언어를 제공합니다. 영어의 경우 example.com/en/blog
, 프랑스어의 경우 example.com/fr/blog
입니다.
다른 언어와 달리 기본 언어가 URL에 표시되지 않도록 하려면 아래의 기본 언어를 숨기는 방법을 참조하세요.
오른쪽에서 왼쪽 (RTL) 스타일 지정 및 언어 태그 선택과 같은 관련 주제에 대한 외부 링크는 리소스 섹션을 참조하세요.
-
지원하려는 각 언어에 대한 디렉터리를 만듭니다. 예를 들어, 영어와 프랑스어를 지원하는 경우 en/
및 fr/
:
디렉터리src/
디렉터리pages/
디렉터리en/
디렉터리fr/
- index.astro
-
기본 언어로 리디렉션하려면 src/pages/index.astro
를 설정하세요.
이 접근 방식은 meta refresh를 사용하며 사이트를 배포하는 방식에 따라 작동합니다. 일부 정적 호스트에서는 사용자 정의 구성 파일을 사용하여 서버 리디렉션을 구성할 수도 있습니다. 자세한 내용은 배포 플랫폼의 설명서를 참조하세요.
SSR 어댑터를 사용하는 경우 Astro.redirect
를 사용하여 서버의 기본 언어로 리디렉션할 수 있습니다.
-
포함하려는 각 콘텐츠 유형에 대해 src/content/
에 폴더를 만들고 지원되는 각 언어에 대한 하위 디렉터리를 추가합니다. 예를 들어 영어 및 프랑스어 블로그 게시물을 지원하려면 다음을 수행하세요.
-
src/content/config.ts
파일을 만들고 각 콘텐츠 유형에 대한 컬렉션을 내보냅니다.
-
동적 경로를 사용하여 lang
및 slug
매개변수를 기반으로 콘텐츠를 가져와 렌더링하세요.
정적 렌더링 모드에서는 getStaticPaths
를 사용하여 각 콘텐츠 항목을 페이지에 매핑합니다.
SSR 모드에서 요청된 항목을 직접 가져옵니다.
사이트 주변의 UI 요소에 대한 레이블을 번역하기 위한 용어 사전을 만듭니다. 이를 통해 방문자는 여러분의 사이트를 완전히 자신의 언어로 경험할 수 있습니다.
-
번역 문자열을 저장할 src/i18n/ui.ts
파일을 만듭니다.
-
두 개의 도우미 함수를 만듭니다. 하나는 현재 URL을 기반으로 페이지 언어를 감지하고, 다른 하나는 src/i18n/utils.ts
파일에서 UI의 다양한 부분에 대한 번역 문자열을 가져옵니다.
-
필요한 경우 도우미를 가져오고 이를 사용하여 현재 언어에 해당하는 UI 문자열을 선택합니다. 예를 들어 nav 컴포넌트는 다음과 같습니다.
-
각 페이지에는 페이지의 언어와 일치하는 <html>
요소의 lang
속성이 있어야 합니다. 이 예시에서 재사용 가능한 레이아웃은 현재 경로에서 언어를 추출합니다.
그런 다음 이 기본 레이아웃을 사용하여 페이지가 올바른 lang
속성을 자동으로 사용하도록 할 수 있습니다.
사용자가 사이트를 읽고 싶은 언어를 선택할 수 있도록 지원하는 다양한 언어에 대한 링크를 만드세요.
-
각 언어에 대한 링크를 표시하는 컴포넌트를 만듭니다.
-
모든 페이지에 표시되도록 <LanguagePicker />
를 사이트에 추가하세요. 아래 예에서는 기본 레이아웃의 사이트 바닥글에 추가합니다.
-
기본 언어를 제외한 각 언어에 대한 디렉터리를 생성합니다. 예를 들어 기본 언어 페이지를 pages/
에 직접 저장하고 번역된 페이지를 fr/
에 저장합니다.
디렉터리src/
디렉터리pages/
- about.astro
- index.astro
디렉터리fr/
-
기능을 전환하려면 src/i18n/ui.ts
파일에 다른 줄을 추가하세요.
-
현재 언어를 기반으로 경로를 번역하려면 src/i18n/utils.ts
파일에 도우미 함수를 추가하세요.
-
필요한 경우 도우미를 가져옵니다. 예를 들어 nav
컴포넌트는 다음과 같습니다.
-
도우미 함수를 사용하여 특정 언어에 대한 경로를 번역할 수도 있습니다. 예를 들어 사용자가 언어를 전환하는 경우:
각 언어에 대한 페이지 경로를 번역하세요.
-
src/i18n/ui.ts
파일에 경로 매핑을 추가합니다.
-
라우터 변환 논리를 추가하려면 src/i18n/utils.ts
파일에서 useTranslatedPath
도우미 함수를 업데이트하세요.
-
src/i18n/utils.ts
파일에 현재 URL을 기반으로 경로가 존재하는 경우 경로를 가져오는 도우미 함수를 만듭니다.
-
도우미 함수를 사용하여 번역된 경로를 얻을 수 있습니다. 예를 들어 번역된 경로가 정의되지 않은 경우 사용자는 홈 페이지로 리디렉션됩니다.
- astro-i18next — 일부 유틸리티 컴포넌트를 포함하는 i18next용 Astro 통합입니다.
- astro-i18n — Astro용 TypeScript 우선 국제화 라이브러리입니다.
- astro-i18n-aut — 페이지 생성 없이
defaultLocale
을 지원하는 i18n용 Astro 통합입니다. 통합은 어댑터와 UI 프레임워크에 구애받지 않습니다.
- paraglide - Astro 아일랜드와 같은 부분적인 하이드레이션 패턴을 위해 특별히 설계된 완전한 타입 안정성을 갖춘 i18n 라이브러리입니다.
Recipes