ऑरेलिया - स्थानीयकरण

ऑरेलिया प्रदान करता है 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

इस फ़ोल्डर में, आपको अपनी इच्छित भाषा के लिए नए फ़ोल्डर जोड़ने होंगे। हम बनाएंगेen साथ में translation.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 - देखें

डेटा ट्रांसलेट करने के कुछ तरीके हैं। हम नाम के एक कस्टम वैल्यू-चार्जर का उपयोग करेंगे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>

जब हम ऐप चलाते हैं, तो हमें निम्न आउटपुट मिलेगा।