Aurelia - Lokalisasi

Aurelia menawarkan i18nplugin. Di bab ini, Anda akan mempelajari cara melokalkan aplikasi Anda menggunakan plugin ini.

Langkah 1 - Instal Plugin

Buka command prompt jendela dan jalankan kode berikut untuk menginstal i18n plugin.

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

Kami juga perlu menginstal plugin backend.

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

Langkah 2 - Buat Folder dan File

Di folder root proyek, kita perlu membuat file locale direktori.

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

Di folder ini, Anda perlu menambahkan folder baru untuk bahasa apa pun yang Anda inginkan. Kami akan membuaten dengan translation.js file di dalam.

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

Langkah 3 - Gunakan Plugin

Anda perlu menggunakan bootstrap manual untuk dapat menggunakan plugin ini. Periksa bab Konfigurasi untuk informasi lebih lanjut. Kami perlu menambahkani18n plugin ke main.js mengajukan.

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());
}

Langkah 4 - Terjemahan File JSON

Ini adalah file tempat Anda dapat menyetel nilai terjemahan. Kami akan menggunakan contoh dari dokumentasi resmi. Itude-DE folder seharusnya digunakan untuk menerjemahkan ke bahasa Jerman, namun kami akan menggunakan frasa bahasa Inggris sebagai gantinya, untuk lebih mudah memahami.

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"
}

Langkah 5 - Tetapkan Lokal

Kami hanya perlu mengimpor i18n plugin dan setel untuk menggunakan kode JSON dari de-DE map.

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!');
      });
   }
}

Langkah 6 - Lihat

Ada beberapa cara untuk menerjemahkan data. Kami akan menggunakan ValueConverter kustom bernamat. Anda dapat melihat dalam contoh berikut berbagai cara memformat data. Bandingkan ini dengantranslation.json file dan Anda akan melihat pola yang digunakan untuk pemformatan.

<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>

Saat kami menjalankan aplikasi, kami akan mendapatkan output berikut.