जीडब्ल्यूटी - इतिहास कक्षा

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

GWT प्रदान करता है History Mechanism इस स्थिति को संभालने के लिए।

GWT एक शब्द का उपयोग करता है tokenजो बस एक स्ट्रिंग है कि आवेदन एक विशेष राज्य में वापस जाने के लिए पार्स कर सकता है। एप्लिकेशन ब्राउज़र के इतिहास में URL टोकन के रूप में इस टोकन को बचाएगा।

उदाहरण के लिए, "pageIndex1" नामक एक इतिहास टोकन को URL में निम्नानुसार जोड़ा जाएगा -

http://www.tutorialspoint.com/HelloWorld.html#pageIndex0

इतिहास प्रबंधन वर्कफ़्लो

चरण 1 - इतिहास समर्थन सक्षम करें

GWT इतिहास समर्थन का उपयोग करने के लिए, हमें पहले अपने होस्ट HTML पेज में iframe का अनुसरण करना होगा।

<iframe src = "javascript:''"
   id = "__gwt_historyFrame"
   style = "width:0;height:0;border:0"></iframe>

चरण 2 - इतिहास में टोकन जोड़ें

निम्न उदाहरण आँकड़े ब्राउज़र इतिहास में टोकन जोड़ने के लिए

int index = 0;
History.newItem("pageIndex" + index);

चरण 3 - इतिहास से टोकन वापस लें

जब उपयोगकर्ता ब्राउज़र के बैक / फॉरवर्ड बटन का उपयोग करता है, तो हम टोकन को पुनः प्राप्त करेंगे और उसके अनुसार हमारी एप्लिकेशन स्थिति को अपडेट करेंगे।

History.addValueChangeHandler(new ValueChangeHandler<String>() {
   @Override
   public void onValueChange(ValueChangeEvent<String> event) {
      String historyToken = event.getValue();
      /* parse the history token */
      try {
         if (historyToken.substring(0, 9).equals("pageIndex")) {
            String tabIndexToken = historyToken.substring(9, 10);
            int tabIndex = Integer.parseInt(tabIndexToken);
            /* select the specified tab panel */
            tabPanel.selectTab(tabIndex);
         } else {
            tabPanel.selectTab(0);
         }
      } catch (IndexOutOfBoundsException e) {
         tabPanel.selectTab(0);
      }
   }
});

अब देखते हैं हिस्ट्री क्लास इन एक्शन।

इतिहास कक्षा - पूरा उदाहरण

यह उदाहरण आपको 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>
      <iframe src = "javascript:''"id = "__gwt_historyFrame"
         style = "width:0;height:0;border:0"></iframe>
      <h1> History Class Demonstration</h1>
      <div id = "gwtContainer"></div>
   </body>
</html>

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

package com.tutorialspoint.client;

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

import com.google.gwt.event.logical.shared.SelectionEvent;
import com.google.gwt.event.logical.shared.SelectionHandler;
import com.google.gwt.event.logical.shared.ValueChangeEvent;
import com.google.gwt.event.logical.shared.ValueChangeHandler;

import com.google.gwt.user.client.History;
import com.google.gwt.user.client.ui.HTML;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.TabPanel;

public class HelloWorld implements EntryPoint {

   /**
    * This is the entry point method.
    */
   public void onModuleLoad() {
      /* create a tab panel to carry multiple pages */  
      final TabPanel tabPanel = new TabPanel();

      /* create pages */
      HTML firstPage = new HTML("<h1>We are on first Page.</h1>");
      HTML secondPage = new HTML("<h1>We are on second Page.</h1>");
      HTML thirdPage = new HTML("<h1>We are on third Page.</h1>");

      String firstPageTitle = "First Page";
      String secondPageTitle = "Second Page";
      String thirdPageTitle = "Third Page";
      tabPanel.setWidth("400");
      
	  /* add pages to tabPanel*/
      tabPanel.add(firstPage, firstPageTitle);
      tabPanel.add(secondPage,secondPageTitle);
      tabPanel.add(thirdPage, thirdPageTitle);

      /* add tab selection handler */
      tabPanel.addSelectionHandler(new SelectionHandler<Integer>() {
         @Override
         public void onSelection(SelectionEvent<Integer> event) {
            /* add a token to history containing pageIndex 
             History class will change the URL of application
             by appending the token to it.
            */
            History.newItem("pageIndex" + event.getSelectedItem());
         }
      });
      
      /* add value change handler to History 
       this method will be called, when browser's 
       Back button or Forward button are clicked 
       and URL of application changes.
       */
      History.addValueChangeHandler(new ValueChangeHandler<String>() {
         @Override
         public void onValueChange(ValueChangeEvent<String> event) {
            String historyToken = event.getValue();
            /* parse the history token */
            try {
               if (historyToken.substring(0, 9).equals("pageIndex")) {
                  String tabIndexToken = historyToken.substring(9, 10);
                  int tabIndex = Integer.parseInt(tabIndexToken);
                  /* select the specified tab panel */
                  tabPanel.selectTab(tabIndex);
               } else {
                  tabPanel.selectTab(0);
               }
            } catch (IndexOutOfBoundsException e) {
               tabPanel.selectTab(0);
            }
         }
      });

      /* select the first tab by default */
      tabPanel.selectTab(0);

      /* add controls to RootPanel */
      RootPanel.get().add(tabPanel);
   }
}

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

  • अब अलग-अलग पृष्ठों का चयन करने के लिए प्रत्येक टैब पर क्लिक करें।

  • आपको ध्यान देना चाहिए, जब प्रत्येक टैब चुना जाता है, तो एप्लिकेशन url बदल दिया जाता है और #pageIndex को url में जोड़ दिया जाता है।

  • आप यह भी देख सकते हैं कि ब्राउज़र के बैक और फ़ॉरवर्ड बटन अभी सक्षम हैं।

  • ब्राउजर के बैक और फॉरवर्ड बटन का उपयोग करें और आप देखेंगे कि अलग-अलग टैब उसके अनुसार चुने जाएंगे।