स्ट्रट्स 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 विषयों और टेम्पलेट्स, है ना?