이 페이지와 원하는 AI 어시스턴트를 사용하여 문서를 요약합니다
버전 기록
- "Solid useIntlayer API 사용법을 직접 속성 액세스로 업데이트"v8.9.02026. 5. 4.
- "기록 초기화"v8.4.102026. 3. 31.
이 페이지의 콘텐츠는 AI를 사용하여 번역되었습니다.
영어 원본 내용의 최신 버전을 보기이 문서를 개선할 아이디어가 있으시면 GitHub에 풀 리퀘스트를 제출하여 자유롭게 기여해 주세요.
문서에 대한 GitHub 링크문서의 Markdown을 클립보드에 복사
Intlayer를 사용하여 Vanilla JS 웹사이트 번역하기 | 국제화(i18n)
목차
대안보다 Intlayer를 선택해야 하는 이유는 무엇입니까?
'i18next' 또는 'i18n.js'와 같은 주요 솔루션과 비교할 때 Intlayer는 다음과 같은 통합 최적화가 제공되는 솔루션입니다.
Intlayer는 프레임워크에 구애받지 않는 콘텐츠 관리, TypeScript 지원 및 국제화 확장(i18n)에 필요한 모든 기능을 제공하여 Vanilla JavaScript와 완벽하게 작동하도록 최적화되었습니다.
대용량 JSON 파일을 페이지에 로드하는 대신 필요한 콘텐츠만 로드하세요. Intlayer는 번들 및 페이지 크기를 최대 50% 줄이는 데 도움이 됩니다.
애플리케이션 콘텐츠의 범위를 지정하면 대규모 애플리케이션의 유지 관리가 용이해집니다. 전체 콘텐츠 코드베이스를 검토해야 하는 정신적 부담 없이 단일 기능 폴더를 복제하거나 삭제할 수 있습니다. 또한 Intlayer는 완전히 유형되어 콘텐츠의 정확성을 보장합니다.
콘텐츠를 같은 위치에 배치하면 LLM(대형 언어 모델)에 필요한 컨텍스트가 줄어듭니다. Intlayer에는 누락된 번역을 테스트하기 위한 CLI, LSP, MCP 및 agent)와 같은 도구 모음도 함께 제공됩니다. 기술, AI 에이전트를 위한 개발자 경험(DX)을 더욱 원활하게 만듭니다.
AI 공급자의 비용으로 선택한 LLM을 사용하여 CI/CD 파이프라인을 번역하려면 자동화를 사용하세요. Intlayer는 또한 콘텐츠 추출을 자동화하는 컴파일러와 백그라운드에서 번역을 돕는 웹 플랫폼을 제공합니다.
대규모 JSON 파일을 구성 요소에 연결하면 성능 및 반응성 문제가 발생할 수 있습니다. Intlayer는 빌드 시 콘텐츠 로딩을 최적화합니다.
Vanilla JS 애플리케이션에 Intlayer를 설정하는 단계별 가이드
1단계: 종속성 설치
npm을 사용하여 필요한 패키지를 설치합니다:
intlayer 설정 관리, 번역, 콘텐츠 선언, 트랜스파일링 및 CLI 명령어를 위한 국제화 도구를 제공하는 핵심 패키지입니다.
vanilla-intlayer Intlayer를 순수 JavaScript / TypeScript 애플리케이션과 통합하는 패키지입니다. 발행/구독 싱글톤(
IntlayerClient) 및 콜백 기반 헬퍼(useIntlayer,useLocale등)를 제공하여 UI 프레임워크에 의존하지 않고도 앱의 모든 부분에서 로케일 변경에 반응할 수 있게 해줍니다.
intlayer standalone CLI의 번들링 내보내기는 설정에 특화된 미사용 패키지, 로케일 및 비필수 로직(리디렉션 또는 접두사 등)을 트리 쉐이킹(tree-shaking)하여 최적화된 빌드를 생성합니다.
2단계: 프로젝트 구성
애플리케이션의 언어를 구성하기 위한 설정 파일을 생성합니다:
이 설정 파일을 통해 로컬라이즈된 URL, 미들웨어 리디렉션, 쿠키 이름, 콘텐츠 선언 위치 및 확장자, 콘솔 내 Intlayer 로그 비활성화 등을 구성할 수 있습니다. 사용 가능한 전체 매개변수 목록은 구성 문서를 참조하세요.
3단계: HTML에 번들 가져오기
intlayer.js 번들을 생성한 후, HTML 파일에서 가져올 수 있습니다:
번들은 window 객체에 Intlayer와 VanillaIntlayer를 글로벌 객체로 노출합니다.
4단계: 진입점에서 Intlayer 부트스트랩
src/main.js에서 콘텐츠가 렌더링되기 전에 installIntlayer()를 호출하여 글로벌 로케일 싱글톤이 준비되도록 합니다.
Markdown 렌더러도 사용하려면 installIntlayerMarkdown()을 호출하세요:
5단계: 콘텐츠 선언하기
번역을 저장하기 위해 콘텐츠 선언을 생성하고 관리합니다:
콘텐츠 선언은
contentDir디렉토리(기본값./src)에 포함되고 콘텐츠 선언 파일 확장자(기본값.content.{json,ts,tsx,js,jsx,mjs,cjs,md,mdx,yaml,yml})와 일치하면 애플리케이션의 어디에서나 정의할 수 있습니다.자세한 내용은 콘텐츠 선언 문서를 참조하세요.
6단계: JavaScript에서 Intlayer 사용하기
window.VanillaIntlayer 객체는 API 헬퍼를 제공합니다. useIntlayer(key, locale?)는 주어진 키에 대한 번역된 콘텐츠를 반환합니다.
리프(leaf) 값을
String()으로 감싸서 문자열로 액세스하면 노드의toString()메서드가 호출되어 번역된 텍스트가 반환됩니다.기본 HTML 속성(예:
alt,aria-label)의 값이 필요한 경우.value를 직접 사용하세요:
(선택 사항) 7단계: 콘텐츠 언어 변경하기
콘텐츠의 언어를 변경하려면 useLocale에서 노출된 setLocale 함수를 사용하세요.
(선택 사항) 8단계: HTML 언어 및 방향 속성 전환
접근성 및 SEO를 위해 <html> 태그의 lang 및 dir 속성을 현재 로케일에 맞게 업데이트합니다.
(선택 사항) 9단계: 로케일별 딕셔너리 지연 로드 (Lazy-load)
로케일별로 딕셔너리를 지연 로드하려면 useDictionaryDynamic을 사용할 수 있습니다. 이는 초기 intlayer.js 파일에 모든 번역을 포함하고 싶지 않을 때 유용합니다.
참고: useDictionaryDynamic을 사용하려면 딕셔너리가 별도의 ESM 파일로 제공되어야 합니다. 이 방식은 일반적으로 딕셔너리를 제공하는 웹 서버가 있는 경우 사용됩니다.
TypeScript 구성
TypeScript 구성에 자동 생성된 타입이 포함되어 있는지 확인하세요.
VS Code 확장 프로그램
Intlayer 개발 경험을 향상시키려면 공식 Intlayer VS Code 확장 프로그램을 설치할 수 있습니다.
이 확장 프로그램은 다음 기능을 제공합니다:
- 번역 키에 대한 자동 완성.
- 누락된 번역에 대한 실시간 오류 감지.
- 번역된 콘텐츠의 인라인 미리보기.
- 번역을 쉽게 생성하고 업데이트할 수 있는 빠른 작업.
확장 프로그램 사용법에 대한 자세한 내용은 Intlayer VS Code 확장 프로그램 문서를 참조하세요.