जीडब्ल्यूटी - यूबिंदर

परिचय

UBBinder एक ऐसा ढांचा है जिसे उपयोगकर्ता इंटरफ़ेस की कार्यक्षमता और दृश्य को अलग करने के लिए डिज़ाइन किया गया है।

  • UBBinder फ्रेमवर्क डेवलपर्स को उन सभी में कॉन्फ़िगर किए गए GWT विजेट वाले HTML पृष्ठों के रूप में gwt एप्लिकेशन बनाने की अनुमति देता है।

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

  • UIBinder उपयोगकर्ता इंटरफ़ेस को परिभाषित करने का एक घोषित तरीका प्रदान करता है।

  • UIBinder UI से प्रोग्रामिक लॉजिक को अलग करता है।

  • UIBinder, JSP के सर्वलेट्स के समान है।

यूबिंदर वर्कफ़्लो

चरण 1 - UI घोषणा एक्सएमएल फ़ाइल बनाएँ

XML / HTML आधारित उपयोगकर्ता इंटरफ़ेस घोषणा फ़ाइल बनाएँ। हमने एक बनाया हैLogin.ui.xml हमारे उदाहरण में फाइल करें।

<ui:UiBinder xmlns:ui = 'urn:ui:com.google.gwt.uibinder'
   xmlns:gwt = 'urn:import:com.google.gwt.user.client.ui' 
   xmlns:res = 'urn:with:com.tutorialspoint.client.LoginResources'>
   <ui:with type = "com.tutorialspoint.client.LoginResources" field = "res">
   </ui:with>
   <gwt:HTMLPanel>
   ...  
   </gwt:HTMLPanel>
</ui:UiBinder>

चरण 2 - बाद के बंधन के लिए ui: फ़ील्ड का उपयोग करें

Ui का उपयोग करें: बाद में बाध्यकारी के लिए जावा फ़ाइल में यूआई क्षेत्र के साथ एक्सएमएल में यूआई क्षेत्र से संबंधित करने के लिए एक्सएमएल / एचटीएमएल तत्व में फ़ील्ड विशेषता।

<gwt:Label ui:field = "completionLabel1" />
<gwt:Label ui:field = "completionLabel2" />

चरण 3 - UI XML का जावा समकक्ष बनाएँ

समग्र विजेट का विस्तार करके XML आधारित लेआउट के जावा आधारित समकक्ष बनाएँ। हमने एक बनाया हैLogin.java हमारे उदाहरण में फाइल करें।

package com.tutorialspoint.client;
   ...
public class Login extends Composite {
   ...
}

चरण 4 - UiField एनोटेशन के साथ जावा UI क्षेत्रों को बांधें

में @UiField एनोटेशन का उपयोग करें Login.java XML- आधारित फ़ील्ड्स में बाइंड करने के लिए समकक्ष वर्ग के सदस्यों को निर्दिष्ट करने के लिए Login.ui.xml

public class Login extends Composite {
   ...
   @UiField
   Label completionLabel1;

   @UiField
   Label completionLabel2;  
   ...
}

चरण 5 - UiTemplate एनोटेशन के साथ UI XML के साथ जावा UI को बांधें

जावा आधारित घटक को बांधने के लिए GWT को निर्देश दें Login.java और XML आधारित लेआउट Login.ui.xml @UiTemplate एनोटेशन का उपयोग करना

public class Login extends Composite {

   private static LoginUiBinder uiBinder = GWT.create(LoginUiBinder.class);

   /*
    * @UiTemplate is not mandatory but allows multiple XML templates
    * to be used for the same widget. 
    * Default file loaded will be <class-name>.ui.xml
    */
   
   @UiTemplate("Login.ui.xml")
   interface LoginUiBinder extends UiBinder<Widget, Login> {
   }
   ...
}

चरण 6 - सीएसएस फ़ाइल बनाएँ

एक बाहरी सीएसएस फ़ाइल बनाएँLogin.css और जावा आधारित संसाधन LoginResources.java सीएसएस शैलियों के बराबर फ़ाइल

.blackText {
   font-family: Arial, Sans-serif;
   color: #000000;
   font-size: 11px;
   text-align: left;
}
...

चरण 7 - सीएसएस फ़ाइल के लिए जावा आधारित संसाधन फ़ाइल बनाएँ

package com.tutorialspoint.client;
...
public interface LoginResources extends ClientBundle {
   public interface MyCss extends CssResource {
      String blackText();

      ...
   }

   @Source("Login.css")
   MyCss style();
}

चरण 8 - जावा यूआई कोड फ़ाइल में सीएसएस संसाधन संलग्न करें।

बाहरी CSS फ़ाइल संलग्न करेंLogin.css जावा आधारित विजेट क्लास के कंस्ट्रक्टर का उपयोग करना Login.java

public Login() {
   this.res = GWT.create(LoginResources.class);
   res.style().ensureInjected();
   initWidget(uiBinder.createAndBindUi(this));
}

UIBinder पूरा उदाहरण

यह उदाहरण आपको GWT में एक UIBinder के उपयोग को दिखाने के लिए सरल चरणों के माध्यम से ले जाएगा। 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'/>
   <!-- Inherit the UiBinder module.                               -->
   <inherits name = "com.google.gwt.uibinder.UiBinder"/>
   <!-- Specify the app entry point class.                         -->
   <entry-point class = 'com.tutorialspoint.client.HelloWorld'/>
  
   <!-- 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>UiBinder Demonstration</h1>
      <div id = "gwtContainer"></div>
   </body>
</html>

अब एक नया UiBinder टेम्पलेट और स्वामी वर्ग बनाएं (फ़ाइल → नई → UiBinder)।

प्रोजेक्ट के लिए क्लाइंट पैकेज चुनें और फिर उसे लॉगिन करें। अन्य सभी चूक को छोड़ दें। समाप्त बटन पर क्लिक करें और प्लगइन एक नया UiBinder टेम्पलेट और स्वामी वर्ग बनाएगा।

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

.blackText {
   font-family: Arial, Sans-serif;
   color: #000000;
   font-size: 11px;
   text-align: left;
}

.redText {
   font-family: Arial, Sans-serif;
   color: #ff0000;
   font-size: 11px;
   text-align: left;
}

.loginButton {
   border: 1px solid #3399DD;
   color: #FFFFFF;
   background: #555555;
   font-size: 11px;
   font-weight: bold;
   margin: 0 5px 0 0;
   padding: 4px 10px 5px;
   text-shadow: 0 -1px 0 #3399DD;
}

.box {
   border: 1px solid #AACCEE;
   display: block;
   font-size: 12px;
   margin: 0 0 5px;
   padding: 3px;
   width: 203px;
}

.background {
   background-color: #999999;
   border: 1px none transparent;
   color: #000000;
   font-size: 11px;
   margin-left: -8px;
   margin-top: 5px;
   padding: 6px;
}

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

package com.tutorialspoint.client;

import com.google.gwt.resources.client.ClientBundle;
import com.google.gwt.resources.client.CssResource;

public interface LoginResources extends ClientBundle {
   /**
    * Sample CssResource.
    */
   public interface MyCss extends CssResource {
      String blackText();

      String redText();

      String loginButton();

      String box();

      String background();
   }

   @Source("Login.css")
   MyCss style();
}

में Login.ui.xml की सामग्री को बदलें src/com.tutorialspoint/client निम्नलिखित के साथ पैकेज

<ui:UiBinder xmlns:ui = 'urn:ui:com.google.gwt.uibinder'
   xmlns:gwt = 'urn:import:com.google.gwt.user.client.ui' 
   xmlns:res = 'urn:with:com.tutorialspoint.client.LoginResources'>
   
   <ui:with type = "com.tutorialspoint.client.LoginResources" field = "res">
   </ui:with>
   
   <gwt:HTMLPanel>
      <div align = "center">
         
         <gwt:VerticalPanel res:styleName = "style.background">
            <gwt:Label text = "Login" res:styleName = "style.blackText" />
            <gwt:TextBox ui:field="loginBox" res:styleName = "style.box" />
            <gwt:Label text = "Password" res:styleName = "style.blackText" />
            <gwt:PasswordTextBox ui:field = "passwordBox" res:styleName = "style.box" />
            
            <gwt:HorizontalPanel verticalAlignment = "middle">
               <gwt:Button ui:field = "buttonSubmit" text="Submit"
                  res:styleName = "style.loginButton" />
               <gwt:CheckBox ui:field = "myCheckBox" />
               <gwt:Label ui:field = "myLabel" text = "Remember me"
                  res:styleName = "style.blackText" />
            </gwt:HorizontalPanel>
            
            <gwt:Label ui:field = "completionLabel1" res:styleName = "style.blackText" />
            <gwt:Label ui:field = "completionLabel2" res:styleName = "style.blackText" />
         </gwt:VerticalPanel>
         
      </div>
   </gwt:HTMLPanel>
   
</ui:UiBinder>

Login.java की सामग्री को इसमें बदलें src/com.tutorialspoint/client निम्नलिखित के साथ पैकेज

package com.tutorialspoint.client;

import com.google.gwt.core.client.GWT;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.logical.shared.ValueChangeEvent;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.uibinder.client.UiHandler;
import com.google.gwt.uibinder.client.UiTemplate;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.TextBox;
import com.google.gwt.user.client.ui.Widget;

public class Login extends Composite {

   private static LoginUiBinder uiBinder = GWT.create(LoginUiBinder.class);

   /*
    * @UiTemplate is not mandatory but allows multiple XML templates
    * to be used for the same widget. 
    * Default file loaded will be <class-name>.ui.xml
    */
   @UiTemplate("Login.ui.xml")
   interface LoginUiBinder extends UiBinder<Widget, Login> {
   }

   @UiField(provided = true)
   final LoginResources res;

   public Login() {
      this.res = GWT.create(LoginResources.class);
      res.style().ensureInjected();
      initWidget(uiBinder.createAndBindUi(this));
   }

   @UiField
   TextBox loginBox;

   @UiField
   TextBox passwordBox;

   @UiField
   Label completionLabel1;

   @UiField
   Label completionLabel2;

   private Boolean tooShort = false;

   /*
    * Method name is not relevant, the binding is done according to the class
    * of the parameter.
    */
   @UiHandler("buttonSubmit")
   void doClickSubmit(ClickEvent event) {
      if (!tooShort) {
         Window.alert("Login Successful!");
      } else {
         Window.alert("Login or Password is too short!");
      }
   }

   @UiHandler("loginBox")
   void handleLoginChange(ValueChangeEvent<String> event) {
      if (event.getValue().length() < 6) {
         completionLabel1.setText("Login too short (Size must be > 6)");
         tooShort = true;
      } else {
         tooShort = false;
         completionLabel1.setText("");
      }
   }

   @UiHandler("passwordBox")
   void handlePasswordChange(ValueChangeEvent<String> event) {
      if (event.getValue().length() < 6) {
         tooShort = true;
         completionLabel2.setText("Password too short (Size must be > 6)");
      } else {
         tooShort = false;
         completionLabel2.setText("");
      }
   }
}

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

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;

public class HelloWorld implements EntryPoint {
   public void onModuleLoad() {
      RootPanel.get().add(new Login());   
   }    
}

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