GWT - कस्टम विजेट

GWT कस्टम उपयोगकर्ता इंटरफ़ेस तत्व बनाने के तीन तरीके प्रदान करता है। अनुसरण करने के लिए तीन सामान्य रणनीतियाँ हैं -

  • Create a widget by extending Composite Class- कस्टम विजेट बनाने का यह सबसे आम और सबसे आसान तरीका है। यहां आप मौजूदा संपत्तियों का उपयोग कस्टम गुणों के साथ समग्र दृश्य बनाने के लिए कर सकते हैं।

  • Create a widget using GWT DOM API in JAVA- GWT बेसिक विजेट्स इस तरह से बनाए जाते हैं। अभी भी कस्टम विजेट बनाने के लिए इसका एक बहुत ही जटिल तरीका है और सावधानी से उपयोग किया जाना चाहिए।

  • Use JavaScript and wrap it in a widget using JSNI- यह आम तौर पर केवल एक अंतिम उपाय के रूप में किया जाना चाहिए। देशी तरीकों के क्रॉस-ब्राउज़र निहितार्थ को ध्यान में रखते हुए, यह बहुत जटिल हो जाता है और डीबग करना भी मुश्किल हो जाता है।

कम्पोजिट क्लास के साथ कस्टम विजेट बनाएं

यह उदाहरण आपको 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'/>

   <!-- 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>Custom Widget Demonstration</h1>
      <div id = "gwtContainer"></div>
   </body>
</html>

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

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.user.client.ui.CheckBox;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.HorizontalPanel;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.TextBox;

public class HelloWorld implements EntryPoint {

   /**
    * A composite of a TextBox and a CheckBox that optionally enables it.
    */
   private static class OptionalTextBox extends Composite implements
   ClickHandler {

      private TextBox textBox = new TextBox();
      private CheckBox checkBox = new CheckBox();
      private boolean enabled = true;

      public boolean isEnabled() {
         return enabled;
      }

      public void setEnabled(boolean enabled) {
         this.enabled = enabled;
      }

      /**
       * Style this widget using .optionalTextWidget CSS class.<br/>
       * Style textbox using .optionalTextBox CSS class.<br/>
       * Style checkbox using .optionalCheckBox CSS class.<br/>
       * Constructs an OptionalTextBox with the given caption 
       * on the check.
       * @param caption the caption to be displayed with the check box
       */
      public OptionalTextBox(String caption) {
         // place the check above the text box using a vertical panel.
         HorizontalPanel panel = new HorizontalPanel();
         // panel.setBorderWidth(1);
         panel.setSpacing(10);
         panel.add(checkBox);
         panel.add(textBox);

         // all composites must call initWidget() in their constructors.
         initWidget(panel);
         
         //set style name for entire widget
         setStyleName("optionalTextWidget");
         
         //set style name for text box
         textBox.setStyleName("optionalTextBox");
         
         //set style name for check box
         checkBox.setStyleName("optionalCheckBox");
         textBox.setWidth("200");
         
         // Set the check box's caption, and check it by default.
         checkBox.setText(caption);
         checkBox.setValue(enabled);
         checkBox.addClickHandler(this);
         enableTextBox(enabled,checkBox.getValue());
      }

      public void onClick(ClickEvent event) {
         if (event.getSource() == checkBox) {
            // When the check box is clicked,
            //update the text box's enabled state.
            enableTextBox(enabled,checkBox.getValue());
         }
      }

      private void enableTextBox(boolean enable,boolean isChecked){
         enable = (enable && isChecked) || (!enable && !isChecked);
         textBox.setStyleDependentName("disabled", !enable);
         textBox.setEnabled(enable);	  
      }
   }

   public void onModuleLoad() {
      // Create an optional text box and add it to the root panel.
      OptionalTextBox otb = new OptionalTextBox(
         "Want to explain the solution?");
      otb.setEnabled(true);
      RootPanel.get().add(otb);
   }    
}

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

You can notice following points

  • समग्र विजेट का विस्तार करके कस्टम विजेट का निर्माण बहुत आसान है।

  • हमने GWT इनबिल्ट विजेट्स, टेक्स्टबॉक्स और चेकबॉक्स के साथ एक विजेट बनाया है और इस प्रकार पुन: प्रयोज्य की अवधारणा का उपयोग किया है।

  • चेकबॉक्स की स्थिति के आधार पर टेक्स्टबॉक्स अक्षम / सक्षम हो जाता है। हमने नियंत्रण को सक्षम / अक्षम करने के लिए एक एपीआई प्रदान किया है।

  • हमने आंतरिक सीएसएस शैलियों को डॉक्यूमेंटेड सीएसएस शैलियों के माध्यम से उजागर किया है।