स्ट्रट्स 2 - थीम्स और टेम्प्लेट

इस अध्याय के लिए वास्तविक ट्यूटोरियल शुरू करने से पहले, हम कुछ परिभाषाओं पर ध्यान दें https://struts.apache.org-

अनु क्रमांक शब्द और विवरण
1

TAG

JSP, FreeMarker, या Velocity के भीतर से कोड का एक छोटा टुकड़ा।

2

TEMPLATE

थोड़ा कोड, आमतौर पर फ्रीमार्कर में लिखा जाता है, जिसे कुछ टैग (HTML टैग) द्वारा प्रदान किया जा सकता है।

3

THEME

सामान्य कार्यक्षमता प्रदान करने के लिए एक साथ पैक किए गए टेम्पलेट्स का संग्रह।

मैं स्ट्रट्स 2 लोकलाइज़ेशन चैप्टर के माध्यम से जाने का भी सुझाव दूंगा क्योंकि हम एक बार फिर अपना उदाहरण प्रस्तुत करने के लिए एक ही उदाहरण लेंगे।

जब आप एक का उपयोग करें Struts 2आपके वेब पेज में <s: submit ...>, <s: textfield ...> आदि जैसे टैग, स्ट्रट्स 2 फ्रेमवर्क प्री-कॉन्फ़िगर स्टाइल और लेआउट के साथ HTML कोड उत्पन्न करता है। स्ट्रट्स 2 तीन अंतर्निहित थीम के साथ आता है -

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

SIMPLE theme

बिना "घंटियाँ और सीटी" के साथ एक न्यूनतम विषय। उदाहरण के लिए, टेक्स्टफील्ड टैग HTML <इनपुट /> टैग को लेबल, सत्यापन, त्रुटि रिपोर्टिंग या किसी अन्य स्वरूपण या कार्यक्षमता के बिना प्रस्तुत करता है।

2

XHTML theme

यह स्ट्रेट्स 2 द्वारा उपयोग की जाने वाली डिफ़ॉल्ट थीम है और सभी मूल बातें प्रदान करता है जो सरल विषय प्रदान करता है और HTML के लिए मानक दो-स्तंभ तालिका लेआउट, HTML के प्रत्येक के लिए लेबल, सत्यापन और त्रुटि रिपोर्टिंग आदि जैसी कई विशेषताएं जोड़ता है।

3

CSS_XHTML theme

यह विषय सभी मूल बातें प्रदान करता है जो साधारण विषय प्रदान करता है और HTML स्ट्रट्स टैग के लिए <div>, HTML स्ट्रट्स टैग के प्रत्येक लेबल के लिए <div> का उपयोग करते हुए मानक दो-स्तंभ CSS- आधारित लेआउट जैसी कई विशेषताएं जोड़ता है, जो सीएसएस स्टाइलशीट के अनुसार रखा गया है। ।

जैसा कि ऊपर उल्लेख किया गया है, यदि आप एक थीम निर्दिष्ट नहीं करते हैं, तो स्ट्रट्स 2 डिफ़ॉल्ट रूप से एक्सएचटीएमएल थीम का उपयोग करेगा। उदाहरण के लिए, यह स्ट्रट्स 2 चुनिंदा टैग -

<s:textfield name = "name" label = "Name" />

HTML मार्कअप के बाद उत्पन्न होता है -

<tr>

   <td class="tdLabel">
      <label for = "empinfo_name" class="label">Name:</label>
   </td>
   <td>
      <input type = "text" name = "name" value = "" id = "empinfo_name"/>
   </td>

</tr>

यहाँ empinfo struts.xml फ़ाइल में परिभाषित क्रिया नाम है।

थीम्स का चयन करना

आप स्ट्रट्स 2, टैग आधार के अनुसार थीम को निर्दिष्ट कर सकते हैं या आप स्टर्लिंग 2 को किस विषय पर निर्दिष्ट करने के लिए निम्न विधियों में से एक का उपयोग कर सकते हैं -

  • विशिष्ट टैग पर विषय विशेषता

  • एक टैग के आसपास के फार्म टैग पर विषय विशेषता

  • पृष्ठ-स्कोप्ड विशेषता को "थीम" नाम दिया गया है

  • "थीम" नाम का अनुरोध-स्कॉप्ड विशेषता

  • "विषय" नाम का सत्र-स्कूप विशेषता

  • "थीम" नाम का एप्लिकेशन-स्कॉप्ड विशेषता

  • Struts.ui.theme में struts.properties (xhtml के लिए डिफ़ॉल्ट) गुण

यदि आप अलग-अलग टैग के लिए विभिन्न विषयों का उपयोग करने के इच्छुक हैं, तो उन्हें टैग स्तर पर निर्दिष्ट करने के लिए सिंटैक्स निम्नलिखित है -

<s:textfield name = "name" label = "Name" theme="xhtml"/>

क्योंकि यह प्रति टैग के आधार पर विषयों का उपयोग करने के लिए बहुत अधिक व्यावहारिक नहीं है, इसलिए बस हम नियम को निर्दिष्ट कर सकते हैं struts.properties निम्नलिखित टैग का उपयोग कर फ़ाइल -

# Standard UI theme
struts.ui.theme = xhtml
# Directory where theme template resides
struts.ui.templateDir = template
# Sets the default template type. Either ftl, vm, or jsp
struts.ui.templateSuffix = ftl

निम्नलिखित परिणाम हम स्थानीयकरण अध्याय से उठाते हैं जहां हमने एक सेटिंग के साथ डिफ़ॉल्ट थीम का उपयोग किया है struts.ui.theme = xhtml में struts-default.properties फ़ाइल जो डिफ़ॉल्ट रूप से struts2-core.xy.z.jar फ़ाइल में आती है।

एक थीम कैसे काम करता है?

किसी दिए गए विषय के लिए, प्रत्येक स्ट्रट्स टैग में एक संबद्ध टेम्पलेट होता है जैसे s:textfield → text.ftl तथा s:password → password.ftl आदि।

ये टेम्पलेट फ़ाइलें struts2-core.xy.z.jar फ़ाइल में ज़िपित होती हैं। ये टेम्प्लेट फ़ाइलें प्रत्येक टैग के लिए पूर्व-निर्धारित HTML लेआउट रखती हैं।

इस तरह, Struts 2 फ्रेमवर्क टैग और संबद्ध टेम्प्लेट का उपयोग करके अंतिम HTML मार्कअप कोड उत्पन्न करता है।

Struts 2 tags + Associated template file = Final HTML markup code.

डिफ़ॉल्ट टेम्पलेट FreeMarker में लिखे गए हैं और उनके पास एक एक्सटेंशन है .ftl

आप वेग या जेएसपी का उपयोग करके अपने टेम्प्लेट भी डिज़ाइन कर सकते हैं और तदनुसार स्ट्रट्स का उपयोग करके कॉन्फ़िगरेशन सेट कर सकते हैं struts.ui.templateSuffix तथा struts.ui.templateDir

नई थीम्स बनाना

एक नया विषय बनाने का सबसे सरल तरीका मौजूदा थीम / टेम्पलेट फ़ाइलों में से किसी को कॉपी करना और आवश्यक संशोधन करना है।

आइए हम एक फ़ोल्डर बनाने के साथ शुरू करते हैं जिसे कहा जाता है templateमें WebContent / WEBINF / वर्गों और हमारे नए विषय के नाम के साथ एक उप-फ़ोल्डर। उदाहरण के लिए, WebContent / WEB-INF / classes / template / mytheme

यहां से, आप स्क्रैच से टेम्प्लेट बनाना शुरू कर सकते हैं, या आप टेम्प्लेट से कॉपी भी कर सकते हैं Struts2 distribution जहाँ आप उन्हें भविष्य में आवश्यकतानुसार संशोधित कर सकते हैं।

हम मौजूदा डिफ़ॉल्ट टेम्पलेट को संशोधित करने जा रहे हैं xhtmlसीखने के उद्देश्य के लिए। अब, हम struts2-core-xyzjar / टेम्पलेट / xhtml से कंटेंट को अपनी थीम डायरेक्टरी में कॉपी करते हैं और केवल WebContent / WEBINF / classes / template / mytheme / control .ftl फाइल को संशोधित करते हैं। जब हम control.ftl खोलेंगे जिसमें निम्नलिखित लाइनें होंगी -

<table class="${parameters.cssClass?default('wwFormTable')?html}"<#rt/>
<#if parameters.cssStyle??> style="${parameters.cssStyle?html}"<#rt/>
</#if>
>

फाइल के ऊपर बदलते हैं control.ftl निम्नलिखित सामग्री है -

<table style = "border:1px solid black;">

अगर आप जांच करेंगे form.ftl तब आप पाएंगे कि control.ftlइस फ़ाइल में उपयोग किया जाता है, लेकिन form.ftl इस फ़ाइल को xHTML थीम से संदर्भित कर रहा है। तो आइए हम इसे इस प्रकार बदलते हैं -

<#include "/${parameters.templateDir}/xhtml/form-validate.ftl" />
<#include "/${parameters.templateDir}/simple/form-common.ftl" />
<#if (parameters.validate?default(false))>
   onreset = "${parameters.onreset?default('clearErrorMessages(this);\
   clearErrorLabels(this);')}"
   
<#else>
   <#if parameters.onreset??>
      onreset="${parameters.onreset?html}"
   </#if>
</#if>
#include "/${parameters.templateDir}/mytheme/control.ftl" />

मुझे लगता है कि, आपको ज्यादा समझ नहीं होगी FreeMarker टेम्पलेट भाषा, फिर भी आप .ft फ़ाइलों को देखकर क्या किया जा सकता है, इसका अच्छा अंदाजा लगा सकते हैं।

हालाँकि, हमें उपरोक्त परिवर्तनों से बचाने के लिए, और अपने स्थानीयकरण उदाहरण पर वापस जाएँ और बनाएँ WebContent/WEB-INF/classes/struts.properties निम्नलिखित सामग्री के साथ फ़ाइल

# Customized them
struts.ui.theme = mytheme
# Directory where theme template resides
struts.ui.templateDir = template
# Sets the template type to ftl.
struts.ui.templateSuffix = ftl

अब इस बदलाव के बाद, प्रोजेक्ट नाम पर राइट क्लिक करें और क्लिक करें Export > WAR Fileएक वार फाइल बनाने के लिए। फिर इस WAR को Tomcat की वेबऐप्स डायरेक्टरी में तैनात करें। अंत में, टॉमकैट सर्वर शुरू करें और URL तक पहुंचने का प्रयास करेंhttp://localhost:8080/HelloWorldStruts2। यह निम्न स्क्रीन का उत्पादन करेगा -

आप प्रपत्र घटक के चारों ओर एक सीमा देख सकते हैं जो कि xhtml विषय से कॉपी करने के बाद हमने विषय में किए गए परिवर्तन का परिणाम है। यदि आप FreeMarker को सीखने में थोड़ा प्रयास करते हैं, तो आप अपने विषयों को बहुत आसानी से बना या संशोधित कर पाएंगे।

मुझे उम्मीद है कि अब आपको एक बुनियादी समझ है Sturts 2 विषयों और टेम्पलेट्स, है ना?