Aurelia-현지화

Aurelia 제공 i18n플러그인. 이 장에서는이 플러그인을 사용하여 앱을 현지화하는 방법을 배웁니다.

1 단계-플러그인 설치

열기 command prompt 창을 열고 다음 코드를 실행하여 설치하십시오. i18n 플러그인.

C:\Users\username\Desktop\aureliaApp>jspm install aurelia-i18n

백엔드 플러그인도 설치해야합니다.

C:\Users\username\Desktop\aureliaApp>jspm install npm:i18next-xhr-backend

2 단계-폴더 및 파일 만들기

프로젝트 루트 폴더에서 locale 예배 규칙서.

C:\Users\username\Desktop\aureliaApp>mkdir locale

이 폴더에서 원하는 언어에 대한 새 폴더를 추가해야합니다. 우리는 만들 것입니다entranslation.js 내부 파일.

C:\Users\username\Desktop\aureliaApp\locale>mkdir en
C:\Users\username\Desktop\aureliaApp\locale\en>touch translation.json

3 단계-플러그인 사용

이 플러그인을 사용하려면 수동 부트 스트랩을 사용해야합니다. 자세한 내용은 구성 장을 확인하십시오. 우리는 추가해야합니다i18n 플러그인 main.js 파일.

main.js

import {I18N} from 'aurelia-i18n';
import XHR from 'i18next-xhr-backend';

export function configure(aurelia) {
   aurelia.use
   .standardConfiguration()
   .developmentLogging()
	
   .plugin('aurelia-i18n', (instance) => {
      // register backend plugin
      instance.i18next.use(XHR);

      // adapt options to your needs (see http://i18next.com/docs/options/)
      instance.setup({
         backend: {                                  
            loadPath: '/locales/{{lng}}/{{ns}}.json',
         },
				
         lng : 'de',
         attributes : ['t','i18n'],
         fallbackLng : 'en',
         debug : false
      });
   });

   aurelia.start().then(a => a.setRoot());
}

4 단계-JSON 파일 번역

번역 값을 설정할 수있는 파일입니다. 공식 문서의 예를 사용합니다. 그만큼de-DE 폴더는 실제로 독일어로 번역하는 데 사용해야하지만 이해하기 쉽도록 대신 영어 구문을 사용합니다.

translation.json

{
   "score": "Score: {{score}}",
   "lives": "{{count}} life remaining",
   "lives_plural": "{{count}} lives remaining",
   "lives_indefinite": "a life remaining",
   "lives_plural_indefinite": "some lives remaining",
   "friend": "A friend",
   "friend_male": "A boyfriend",
   "friend_female": "A girlfriend"
}

5 단계-로케일 설정

가져 오기만하면됩니다. i18n 플러그인을 사용하고 JSON 코드를 사용하도록 설정합니다. de-DE 폴더.

app.js

import {I18N} from 'aurelia-i18n';

export class App {
   static inject = [I18N];
	
   constructor(i18n) {
      this.i18n = i18n;
      this.i18n
      .setLocale('de-DE')
		
      .then( () => {
         console.log('Locale is ready!');
      });
   }
}

6 단계-보기

데이터를 번역하는 방법에는 두 가지가 있습니다. 이름이 지정된 사용자 정의 ValueConverter를 사용합니다.t. 다음 예제에서 다양한 데이터 형식 지정 방법을 볼 수 있습니다. 이것을translation.json 파일을 열면 서식 지정에 사용되는 패턴을 확인할 수 있습니다.

<template>
   <p>
      Translation with Variables: <br />
      ${ 'score' | t: {'score': 13}}
   </p>

   <p>
      Translation singular: <br />
      ${ 'lives' | t: { 'count': 1 } }
   </p>

   <p>
      Translation plural: <br />
      ${ 'lives' | t: { 'count': 2 } }
   </p>

   <p>  
      Translation singular indefinite: <br />
      ${ 'lives' | t: { 'count': 1, indefinite_article: true  } }
   </p>

   <p>
      Translation plural indefinite: <br />
      ${ 'lives' | t: { 'count': 2, indefinite_article: true } }
   </p>

   <p>
      Translation without/with context: <br />
      ${ 'friend' | t } <br />
      ${ 'friend' | t: { context: 'male' } } <br />
      ${ 'friend' | t: { context: 'female' } }
   </p>
	
</template>

앱을 실행하면 다음과 같은 출력이 표시됩니다.