जीडब्ल्यूटी - अंतर्राष्ट्रीयकरण

GWT एक GWT एप्लिकेशन का अंतर्राष्ट्रीयकरण करने के तीन तरीके प्रदान करता है, हम स्टेटिक स्ट्रिंग अंतर्राष्ट्रीयकरण के उपयोग को सबसे अधिक परियोजनाओं के बीच उपयोग किया जाता है।

अनु क्रमांक। तकनीक और विवरण
1

Static String Internationalization

यह तकनीक सबसे अधिक प्रचलित है और रनटाइम में बहुत कम ओवरहेड की आवश्यकता होती है; स्थिरांक और पैरामीटरित स्ट्रिंग्स दोनों के अनुवाद के लिए एक बहुत ही कुशल तकनीक है, जिसे लागू करना सबसे सरल है।

स्टैटिक स्ट्रिंग अंतर्राष्ट्रीयकरण अनुवादित स्ट्रिंग्स और पैरामीटर किए गए संदेशों को संग्रहीत करने के लिए मानक जावा गुण फ़ाइलों का उपयोग करता है, और उनके मूल्यों को पुनः प्राप्त करने के लिए दृढ़ता से टाइप किए गए जावा इंटरफेस बनाए जाते हैं।

2

Dynamic String Internationalization

यह तकनीक स्थैतिक स्ट्रिंग अंतर्राष्ट्रीयकरण की तुलना में बहुत लचीली लेकिन धीमी है। होस्ट पृष्ठ में स्थानीय स्ट्रिंग्स शामिल हैं, इसलिए जब हम एक नया लोकेल जोड़ते हैं तो एप्लिकेशन को फिर से कनेक्ट करने की आवश्यकता नहीं होती है। यदि GWT एप्लिकेशन को मौजूदा सर्वर-साइड स्थानीयकरण प्रणाली के साथ एकीकृत किया जाना है, तो इस तकनीक का उपयोग किया जाना है।

3

Localizable Interface

यह तकनीक तीनों तकनीकों में सबसे शक्तिशाली है। स्थानीयकरण को लागू करने से हम कस्टम प्रकार के स्थानीयकृत संस्करण बना सकते हैं। यह एक उन्नत अंतर्राष्ट्रीयकरण तकनीक है।

GWT एप्लिकेशन का अंतर्राष्ट्रीयकरण करने का वर्कफ़्लो

चरण 1 - गुण फ़ाइलें बनाएँ

एप्लिकेशन में उपयोग किए जाने वाले संदेशों के साथ गुण फ़ाइल बनाएं। हमने एक बनाया हैHelloWorldMessages.properties हमारे उदाहरण में फाइल करें।

enterName = Enter your name
clickMe = Click Me
applicationTitle = Application Internationalization Demonstration
greeting = Hello {0}

अनुवादित मानों के लिए अनुवादित मान युक्त गुण फ़ाइलें बनाएँ। हमने एक बनाया हैHelloWorldMessages_de.propertiesहमारे उदाहरण में फाइल करें। इस फ़ाइल में जर्मन भाषा में अनुवाद हैं। _de जर्मन लोकेल को निर्दिष्ट करता है और हम अपने आवेदन में जर्मन भाषा का समर्थन करने जा रहे हैं।

यदि आप ग्रहण का उपयोग करके गुण फ़ाइल बना रहे हैं तो फ़ाइल की एन्कोडिंग को UTF-8 में बदल दें। फ़ाइल को चुनें और फिर उसके गुण विंडो खोलने के लिए उसमें राइट-क्लिक करें। पाठ फ़ाइल एन्कोडिंग के रूप में चुनें Other UTF-8। लागू करें और परिवर्तन सहेजें।

enterName = Geben Sie Ihren Namen
clickMe = Klick mich
applicationTitle = Anwendung Internationalisierung Demonstration
greeting = Hallo {0}

चरण 2 - मॉड्यूल डिस्क्रिप्टर XML फ़ाइल में i18n मॉड्यूल जोड़ें

मॉड्यूल फ़ाइल अपडेट करें HelloWorld.gwt.xml जर्मन लोकेल के लिए समर्थन शामिल करना

<?xml version = "1.0" encoding = "UTF-8"?>
<module rename-to = 'helloworld'>
   ...
   <extend-property name = "locale" values="de" />
   ...
</module>

चरण 3 - गुण फ़ाइल के बराबर इंटरफ़ेस बनाएँ

GWT के संदेश इंटरफ़ेस का विस्तार करके आंतरिककरण के लिए समर्थन शामिल करने के लिए HelloWorldMessages.java इंटरफ़ेस बनाएँ। यह गुण फ़ाइल में कुंजियों के समान विधि नाम होना चाहिए। स्थान धारक को स्ट्रिंग तर्क के साथ बदल दिया जाएगा।

public interface HelloWorldMessages extends Messages {
	
   @DefaultMessage("Enter your name")
   String enterName();
 
   @DefaultMessage("Click Me")
   String clickMe();
 
   @DefaultMessage("Application Internalization Demonstration")
   String applicationTitle();

   @DefaultMessage("Hello {0}")
   String greeting(String name);
}

चरण 4 - यूआई घटक में संदेश इंटरफेस का उपयोग करें।

की वस्तु का उपयोग करें HelloWorldMessages में HelloWorld संदेश पाने के लिए।

public class HelloWorld implements EntryPoint {
   
   /* create an object of HelloWorldMessages interface 
      using GWT.create() method */
   private HelloWorldMessages messages = 
   GWT.create(HelloWorldMessages.class);
   
   public void onModuleLoad() {
   ...
      Label titleLabel = new Label(messages.applicationTitle());
      //Add title to the application
      RootPanel.get("gwtAppTitle").add(titleLabel);
   ...
   }
}

अंतर्राष्ट्रीयकरण - पूर्ण उदाहरण

यह उदाहरण आपको GWT एप्लिकेशन के अंतर्राष्ट्रीयकरण क्षमता को प्रदर्शित करने के लिए सरल चरणों के माध्यम से ले जाएगा।

GWT में बनाए गए GWT एप्लिकेशन को अपडेट करने के लिए निम्नलिखित चरणों का पालन करें - एप्लिकेशन अध्याय बनाएं -

कदम विवरण
1 GWT में बताए अनुसार एक पैकेज com.tutorialspoint के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 HelloWorld.gwt.xml , HelloWorld.css , HelloWorld.html और HelloWorld.java को नीचे बताए अनुसार संशोधित करें। बाकी फाइलें अपरिवर्तित रखें।
3 लागू तर्क के परिणाम को सत्यापित करने के लिए एप्लिकेशन को संकलित करें और चलाएं।

निम्नलिखित संशोधित मॉड्यूल विवरणक की सामग्री है src/com.tutorialspoint/HelloWorld.gwt.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<module rename-to = 'helloworld'>
  <!-- Inherit the core Web Toolkit stuff.                        -->
  <inherits name = 'com.google.gwt.user.User'/>

  <!-- Inherit the default GWT style sheet.                       -->
  <inherits name = 'com.google.gwt.user.theme.clean.Clean'/>

  <!-- Specify the app entry point class.                         -->
  <entry-point class = 'com.tutorialspoint.client.HelloWorld'/>
  <extend-property name = "locale" values="de" />
  <!-- Specify the paths for translatable code                    -->
  <source path = 'client'/>
  <source path = 'shared'/>

</module>

निम्नलिखित संशोधित स्टाइल शीट फ़ाइल की सामग्री है war/HelloWorld.css

body {
   text-align: center;
   font-family: verdana, sans-serif;
}

h1 {
   font-size: 2em;
   font-weight: bold;
   color: #777777;
   margin: 40px 0px 70px;
   text-align: center;
}

निम्नलिखित संशोधित HTML होस्ट फ़ाइल की सामग्री है war/HelloWorld.html

<html>
   <head>
      <title>Hello World</title>
      <link rel = "stylesheet" href = "HelloWorld.css"/>
      <script language = "javascript" src = "helloworld/helloworld.nocache.js">
      </script>
   </head>
   <body>

      <h1 id = "gwtAppTitle"></h1>
      <div id = "gwtContainer"></div>

   </body>
</html>

अब में HelloWorldMessages.properties फ़ाइल बनाएँ src/com.tutorialspoint/client पैकेज और उसमें निम्नलिखित सामग्री रखें

enterName = Enter your name
clickMe = Click Me
applicationTitle = Application Internationalization Demonstration
greeting = Hello {0}

अब HelloWorldMessages_de.properties फ़ाइल बनाएँ src/com.tutorialspoint/client पैकेज और उसमें निम्नलिखित सामग्री रखें

enterName = Geben Sie Ihren Namen
clickMe = Klick mich
applicationTitle = Anwendung Internationalisierung Demonstration
greeting = Hallo {0}

अब में HelloWorldMessages.java क्लास बनाएं src/com.tutorialspoint/client पैकेज और उसमें निम्नलिखित सामग्री रखें

package com.tutorialspoint.client;
import com.google.gwt.i18n.client.Messages;

public interface HelloWorldMessages extends Messages {	
   @DefaultMessage("Enter your name")
   String enterName();
 
   @DefaultMessage("Click Me")
   String clickMe();
 
   @DefaultMessage("Application Internationalization Demonstration")
   String applicationTitle();

   @DefaultMessage("Hello {0}")
   String greeting(String name);
}

आइए हम जावा फ़ाइल की निम्न सामग्री रखते हैं src/com.tutorialspoint/HelloWorld.java जिसका उपयोग करके हम GWT कोड की अंतर्राष्ट्रीयकरण क्षमता का प्रदर्शन करेंगे।

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.core.client.GWT;

import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.KeyCodes;
import com.google.gwt.event.dom.client.KeyUpEvent;
import com.google.gwt.event.dom.client.KeyUpHandler;

import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.DecoratorPanel;
import com.google.gwt.user.client.ui.HasHorizontalAlignment;
import com.google.gwt.user.client.ui.HorizontalPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.TextBox;
import com.google.gwt.user.client.ui.VerticalPanel;

public class HelloWorld implements EntryPoint {

   /* create an object of HelloWorldMessages interface 
      using GWT.create() method */
   private HelloWorldMessages messages = 
   GWT.create(HelloWorldMessages.class);
   
   public void onModuleLoad() {
      /*create UI */
      final TextBox txtName = new TextBox(); 
      txtName.setWidth("200");
      txtName.addKeyUpHandler(new KeyUpHandler() {
         @Override
         public void onKeyUp(KeyUpEvent event) {
            if(event.getNativeKeyCode() == KeyCodes.KEY_ENTER){
               Window.alert(getGreeting(txtName.getValue()));
            }				
         }
      });
      Label lblName = new Label(messages.enterName() + ": ");

      Button buttonMessage = new Button(messages.clickMe() + "!");

      buttonMessage.addClickHandler(new ClickHandler() {			
         @Override
         public void onClick(ClickEvent event) {
            Window.alert(getGreeting(txtName.getValue()));
         }
      });

      HorizontalPanel hPanel = new HorizontalPanel();	
      hPanel.add(lblName);
      hPanel.add(txtName);      

      VerticalPanel vPanel = new VerticalPanel();
      vPanel.setSpacing(10);
      vPanel.add(hPanel);
      vPanel.add(buttonMessage);
      vPanel.setCellHorizontalAlignment(buttonMessage, 
      HasHorizontalAlignment.ALIGN_RIGHT);

      DecoratorPanel panel = new DecoratorPanel();
      panel.add(vPanel);
      Label titleLabel = new Label(messages.applicationTitle());
      //Add title to the application
      RootPanel.get("gwtAppTitle").add(titleLabel);
      // Add widgets to the root panel.
      RootPanel.get("gwtContainer").add(panel);
   }  
   
   public String getGreeting(String name){
      return messages.greeting(name + "!");
   }
}

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाते हैं, तो हम एप्लिकेशन को विकास मोड में संकलित करें और चलाएं जैसा कि हमने GWT में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा -

अब URL को लोकेल = de.Set URL पर अपडेट करें - http://127.0.0.1:8888/HelloWorld.html?gwt.codesvr=127.0.0.1:9997&locale=de। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा -