जीडब्ल्यूटी - अंतर्राष्ट्रीयकरण
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। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा -