रिचफेस - क्विक गाइड

रिचफेसेस जेएसएफ तकनीक के लिए एक खुला स्रोत घटक पुस्तकालय है। यह JBoss द्वारा विकसित और डिज़ाइन किया गया है। RichFaces ने जेएसएफ डेवलपर को फ्रंट एंड के पूर्व ज्ञान के बिना पुन: प्रयोज्य मार्कअप और AJAX क्षमताएं प्रदान की हैं। रिचफेसेस JSF 2 के ऊपर विकसित किया गया था, इसलिए यह JSF के समान जीवन चक्र का अनुसरण करता है। इन-बिल्ट AJAX सपोर्ट और कस्टमाइज़ेबल लुक और फील फीचर्स ने एंटरप्राइज़ जावा एप्लिकेशन के लिए एक नया क्षितिज सक्षम किया है।

फायदे और नुकसान

कुछ निम्नलिखित हैं advantages RichFaces का उपयोग कर के

AJAX support- रिचफेसेस पुराने बॉयलरप्लेट AJAX को समाप्त करता है, वेबपेजों में मार्कअप को शामिल करने के लिए जावास्क्रिप्ट कोड। रिचफेस का उपयोग करते हुए, एक डेवलपर AJAX के पूर्व ज्ञान के बिना मार्क-ऑन-द-फ्लाई को शामिल कर सकता है।

Component Development Kit (CDK)- जैसा कि पहले बताया गया है, डेवलपर को एप्लिकेशन में उपयोग किए जाने वाले मार्कअप पर ध्यान केंद्रित करने की आवश्यकता नहीं है, उन सभी फंक्शंस का उपयोग करने के लिए रिचफैस टैग को शामिल करना होगा। मार्कअप का यह स्वचालित निर्माण सीडीके नामक रनटाइम वातावरण द्वारा किया जाएगा।

Resource handling - रिफ़फेसेस विभिन्न बाइनरी फ़ाइलों जैसे छवि, एक्सेल, स्प्रेडशीट, आदि को बनाने के लिए अतिरिक्त सहायता प्रदान करता है।

Skinning- स्किनिंग एक आधुनिक दृष्टिकोण है जिसे जेएसएफ में पेश किया गया है, जो आवेदन के रूप और अनुभव को नियंत्रित करना बहुत आसान बनाता है। विशेष रूप से केंद्रीकृत रंग प्रबंधन विभिन्न अन्य अनुकूलन मापदंडों का उपयोग करके इसे एक डेवलपर के लिए बहुत आसान बनाता है।

कुछ निम्नलिखित हैं disadvantages RichFaces का उपयोग कर के

Resource - यह एक काफी नई तकनीक होने के नाते, अच्छी गुणवत्ता के संसाधन प्राप्त करना अमीर चेहरे के डेवलपर के लिए एक बड़ी समस्या है।

Complex- विभिन्न चरणों के माध्यम से संक्रमण और गतिशील मार्कअप का निर्माण सीडीके की पूरी जिम्मेदारी है। सीडीके की आंतरिक प्रसंस्करण को समझना थोड़ा जटिल है और पारंपरिक फ्रंट-एंड डेवलपर के लिए भ्रामक है।

इस अध्याय में, आप हमारे विकास के वातावरण को स्थापित करेंगे और अपने सिस्टम को ऐसे कॉन्फ़िगर करेंगे कि आप रिचफेसेस के विकास के साथ आगे बढ़ सकें।

तकनीकी आवश्यकताएँ

तकनीकी आवश्यकता के अनुसार आप जेडडीके, एप्लिकेशन सर्वर या अपनी पसंद के किसी भी आईडीई को कॉन्फ़िगर करना सीखेंगे।

सिस्टम आवश्यकताएं

आप किसी भी रनिंग सिस्टम का उपयोग कर सकते हैं, मेमोरी, रैम और ऑपरेटिंग सिस्टम पर कोई प्रतिबंध नहीं है।

JDK स्थापना

आगे बढ़ने से पहले, आपके पास आपके सिस्टम पर JDK कॉन्फ़िगर होना चाहिए। कृपया JDK 7 या इसके बाद के संस्करण को डाउनलोड करने और स्थापित करने के लिए ओरेकल की आधिकारिक वेबसाइट देखें । आपको जावा के लिए पर्यावरण चर सेट करना पड़ सकता है ताकि यह ठीक से काम कर सके। विंडोज ऑपरेटिंग सिस्टम में अपनी स्थापना को सत्यापित करने के लिए, कमांड प्रॉम्प्ट में "जावा-वर्सन" को हिट करें और आउटपुट के रूप में यह आपको आपके सिस्टम में स्थापित जावा संस्करण दिखाएगा।

आईडीई स्थापना

इंटरनेट पर आईडीई के नंबर उपलब्ध हैं। आप किसी का भी उपयोग आप चुन सकते हैं। इस ट्यूटोरियल के लिए, हम नेटबियंस 8.2 का उपयोग करते हैं। आप निम्न तालिका में विभिन्न आईडीई के डाउनलोड लिंक पा सकते हैं।

आईडीई का नाम स्थापना लिंक
NetBeans https://netbeans.org/downloads/
ग्रहण www.eclipse.org/downloads/
Intellij www.jetbrains.com/idea/download/#section=windows

हमेशा एक हालिया सॉफ़्टवेयर संस्करण का उपयोग करने की सिफारिश की जाती है ताकि वह इससे अधिकतम सुविधा को खींच सके। इस ट्यूटोरियल के लिए, हम JDK 8 के साथ NetBeans IDE 8.2 का उपयोग करेंगे।

सर्वर आवश्यकताएँ

एक एप्लिकेशन सर्वर के रूप में, आप टॉमकैट का उपयोग करेंगे। इस अध्याय में, आप सिस्टम में टॉमकैट सर्वर को कॉन्फ़िगर करेंगे। यदि आप NetBeans का नवीनतम संस्करण स्थापित कर रहे हैं, तो आप सीधे Apache Tomcat को NetBeans IDE के साथ स्थापित कर सकते हैं। यदि आप ऐसा नहीं कर रहे हैं, तो टॉम्कट का नवीनतम संस्करण TOMCAT की आधिकारिक वेबसाइट से डाउनलोड करें । अपने C ड्राइव या प्रोग्राम फ़ाइलों में निकाली गई Tomcat फ़ाइलों को रखें। इन फ़ाइलों का उपयोग अगले चरण में किया जाएगा।

ग्राहक की आवश्यकताएं

RichFaces एक UI घटक है। इस प्रकार, प्रत्येक यूआई घटक की तरह, इंटरनेट ब्राउज़र आपके एप्लिकेशन के लिए क्लाइंट के रूप में कार्य करेगा। आप किसी भी आधुनिक इंटरनेट ब्राउजर जैसे IE, सफारी, क्रोम आदि का उपयोग कर सकते हैं।

विकास की आवश्यकताएँ

आवश्यक जार डाउनलोड करना: कृपया JBOSS की आधिकारिक वेबसाइट पर जाएँ और JBoss जार फ़ाइलों की नवीनतम स्थिर रिलीज़ डाउनलोड करें। फ़ाइलों को निकालें। RichFaces Application को विकसित करने के लिए आपको निम्नलिखित जार की आवश्यकता होगी।

  • richfaces-a4j-4.5.17.Final.jar
  • richfaces-core-4.5.17.Final.jar
  • richfaces-rich-4.5.17.Final.jar
  • cssparser-0.9.18.jar
  • guava-19.0.jar
  • sac-1.3.jar

एक परियोजना का निर्माण

इस खंड में, हम एक डेमो एप्लिकेशन बनाते हैं जिसका उपयोग रिचफेसेस के बारे में अधिक जानने के लिए बाद में किया जाएगा। आगे बढ़ने से पहले, यह अत्यधिक अनुशंसा की जाती है कि आप पहले उल्लेखित सभी आवश्यक सॉफ़्टवेयर और जार फ़ाइलों को डाउनलोड और इंस्टॉल करें।

Step 1- नेटबीन्स आईडीई खोलें। फ़ाइल → नई परियोजना पर जाएं। आपको निम्न स्क्रीनशॉट पर पुनः निर्देशित किया जाएगा।

Step 2 - क्रमशः "श्रेणियाँ" और "प्रोजेक्ट" टैब में "जावा वेब" और "वेब एप्लिकेशन" का चयन करें और "अगला" मारा।

Step 3- अगले टैब में, आपको एक प्रोजेक्ट नाम प्रदान करना होगा। यहाँ, हम इसे "RichFaceTutorial" नाम देते हैं। फिर, "अगला" मारा। आपको निम्न स्क्रीनशॉट पर पुनः निर्देशित किया जाएगा। जहां आप सर्वर विवरण स्थापित करेंगे।

Step 4- ड्रॉपडाउन से "अपाचे टोमाकट" का चयन करें और "जोड़ें" मारा। एक बार जब आप "ऐड" हिट करते हैं, तो आपको एक अलग स्क्रीन पर रीडायरेक्ट किया जाएगा, जहां आपको अपने सर्वर को कॉन्फ़िगर करने की आवश्यकता है। सर्वर को कॉन्फ़िगर करने के लिए, आपको पिछले अनुभाग में डाउनलोड की गई सर्वर फ़ाइलों की आवश्यकता होगी।

Step 5- उपरोक्त स्क्रीनशॉट में दिखाए अनुसार सूची में से "Apache Tomcat या TomEE" चुनें और "Next" पर क्लिक करें। आपको निम्न स्क्रीन पर पुनः निर्देशित किया जाएगा।

Step 6- सर्वर लोकेशन में, आपको डाउनलोड की गई टॉम्कट फाइल लोकेशन उपलब्ध करानी होगी। "ब्राउज़ करें" मारो और आवश्यक फ़ोल्डर पथ पर नेविगेट करें और "समाप्त करें" पर हिट करें। एक बार जब आपका सर्वर सफलतापूर्वक जुड़ जाता है, तो आपको पहली स्क्रीन पर पुनर्निर्देशित किया जाएगा। "अगला" मारो और आपको एप्लिकेशन में जोड़ने के लिए विभिन्न रूपरेखाओं को चुनने का मौका मिलेगा जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 7 - "JavaServer चेहरे" का चयन करें और "JavaServer चेहरे विन्यास" में आप "RichFaces" का चयन करें और "खत्म" मारा।

यदि आपको विकल्प के रूप में "RichFaces" नहीं मिलता है, तो आप निर्माण पथ से आवश्यक जार फ़ाइल जोड़ सकते हैं। इस चरण के बाद, आपका एप्लिकेशन एप्लिकेशन सर्वर पर तैनात करने के लिए तैयार है। उपरोक्त सभी चरणों को पूरा करने के बाद आवेदन की परियोजना निर्देशिका संरचना निम्नलिखित है।

Step 8- आगे बढ़ें और "index.xhtml" फ़ाइल पर बायाँ-क्लिक करें और फ़ाइल चलाएँ। आपको ब्राउज़र में निम्न आउटपुट दिखाई देगा।

वास्तविक जीवन के आवेदन में, आपको आवश्यक युद्ध फ़ाइल उत्पन्न करनी होगी और आवेदन सर्वर में तैनात करना होगा, क्योंकि सभी पृष्ठ आपस में जुड़े होंगे।

हालाँकि, इस ट्यूटोरियल के लिए हम एप्लिकेशन पेज वार करेंगे क्योंकि हमें विभिन्न टैग्स की विभिन्न विशेषताओं को दिखाने की आवश्यकता है।

Red Hat के आधिकारिक दस्तावेज़ के अनुसार, कुल पाँच घटक हैं जो आंतरिक रूप से समृद्ध उपयोगकर्ता अनुभव प्रदान करने के लिए काम करते हैं। निम्नलिखित पांच घटक हैं।

  • AJAX Filter- AJAX फ़िल्टर क्लाइंट ब्राउजर से आने वाले विभिन्न प्रकार के अनुरोधों के बीच अंतर करने के लिए उपयोग किया जाता है। इस घटक को अनुप्रयोग में शामिल करने के लिए, आपको अपने आवेदन की web.xml फ़ाइल में RichFaces Filter पंजीकृत करना होगा। AJAX फ़िल्टर JSF अनुप्रयोगों के विभिन्न चरणों में अलग तरह से कार्य करता है।

  • AJAX Action Components - एक्शन घटक ब्राउज़र से AJAX इंजन को क्लाइंट अनुरोध भेजने के लिए जिम्मेदार हैं, जहां से यह अनुरोध को संसाधित करेगा और प्रतिक्रिया के रूप में आवश्यक दृश्य प्रस्तुत करेगा।

  • AJAX Containers- AJAX कंटेनर वैचारिक रूप से स्प्रिंग कंटेनर के समान है। यह मूल रूप से AJAX अनुरोध को संसाधित करने के लिए क्लाइंट ब्राउज़र के एक विशिष्ट क्षेत्र को पहचान रहा है।

  • Skinnability- स्किन और थीम को स्किनबिलिटी के रूप में जाना जाता है। यह मॉड्यूल संपूर्ण रूप से देखने और महसूस करने में व्यापक सहायता प्रदान करने के लिए स्वतंत्र रूप से कार्य करता है।

  • RichFaces JavaScript Engine- जावास्क्रिप्ट इंजन क्लाइंट पक्ष पर चलता है जो प्रतिक्रिया तैयार करने के लिए AJAX इंजन को अपडेट भेजता है। यह इंजन स्वचालित रूप से काम करता है, इसलिए हमें इसे नियंत्रित करने के लिए कोड की कोई अतिरिक्त लाइन लिखने की आवश्यकता नहीं है।

एमवीसी प्रतिमान में रिचफेसेस एप्लिकेशन का वास्तु चित्र निम्नलिखित है।

उपरोक्त छवि में, उपयोगकर्ता की गतिविधि को "जेएस इवेंट" के रूप में संसाधित किया जाएगा। बाद में, "जेएस इवेंट" को "एक्सएमएल फ़िल्टर" में प्रेषित किया जाएगा, जो कि AJAX फ़िल्टर के एक घटक के अलावा कुछ भी नहीं है। "XML फ़िल्टर" उपयोगकर्ता के अनुरोधों को बनाने और संसाधित करने के लिए जिम्मेदार है। अन्य सभी घटक विभिन्न जार फ़ाइलों के लिए आंतरिक हैं। हमें उन कार्यात्मकताओं का उपयोग करने के लिए उपयुक्त टैग लाइब्रेरी का उपयोग करने की आवश्यकता है।

इस अध्याय में, हम RichFaces की कुछ बुनियादी अवधारणाओं को देखेंगे और हम सीखेंगे कि AJAX अनुरोधों और कई अन्य कार्यात्मकताओं के प्रसंस्करण के साथ RichFaces कैसे व्यवहार करते हैं।

AJAX अनुरोध संसाधित करना

जैसा कि पहले उल्लेख किया गया है, रिचफेसेस समृद्ध यूआई घटक प्रदान करता है जो वेब एप्लिकेशन में AJAX कार्यात्मकताओं को बिना किसी AJAX कोड को लागू किए बिना सक्षम बनाता है। इन सभी AJAX क्षमताओं को इसके माध्यम से पेश किया जाता हैa4:j टैग लाइब्रेरी। <a4j:commandLink> , <a4j:commandButton>, <a4j:support>, तथा <a4j:poll>चार टैग हैं जो डेवलपर को वेब एप्लिकेशन में AJAX कार्यात्मकताओं को शामिल करने में मदद करते हैं। हम बाद के अध्याय में टैग पुस्तकालयों के बारे में अधिक जानेंगे।

आंशिक वृक्ष प्रसंस्करण

एक पारंपरिक AJAX आवेदन में, सभी इनपुट फ़ील्ड को एक पेड़ के विभिन्न नोड्स के रूप में संसाधित किया जाएगा, हालांकि, रिचफेसेस में हमारे पास आंशिक रूप से ट्री नोड्स सबमिट करने और आवश्यक फ़ील्ड को मान्य करने का एक विकल्प है।

आइए इस बारे में अधिक समझने के लिए एक उदाहरण पर विचार करें। मान लीजिए, HTML में कुल पांच तत्व हैं - "नाम", "कर्मचारी आईडी", "कर्मचारी वेतन", "कर्मचारी पता", और "कर्मचारी विभाग"। अब आप केवल Employee id को ही मान्य या प्रोसेस करना चाहते हैं, जो कि RichFaces का उपयोग करके संभव हो सकता है लेकिन AJAX के उपयोग से संभव नहीं है। आपको पूरे फॉर्म को सर्वर पर सबमिट करना होगा। रिचफेस एक निष्पादित विशेषता प्रदान करता है जो एक विशिष्ट घटक की पहचान कर सकता है और उसी को संसाधित कर सकता है। निम्नलिखित निष्पादन विशेषताओं के विभिन्न स्तर उपलब्ध हैं।

  • @all - यह विशेषता आपके सभी डेटा को प्रोसेस करेगी।

  • @none - इसका उपयोग तब किया जा सकता है जब आप किसी भी डेटा को प्रोसेस नहीं करना चाहते हैं।

  • @this - यह केवल अनुरोध घटक को संसाधित करेगा।

  • @form - यह पूरे फॉर्म को प्रोसेस करेगा जिसमें अनुरोध करने वाला घटक है।

  • @region - यह एक वेबपेज के एक विशिष्ट क्षेत्र को प्रोसेस करेगा।

आंशिक अद्यतन देखें

इनपुट फील्ड्स की तरह, रिचफेसेस विभिन्न विचारों को अपडेट करने के लिए समान विकल्प प्रदान करता है। डेवलपर्स अपनी पसंद के अनुसार दृश्य को अनुकूलित कर सकते हैं। निष्पादित विशेषता की तरह, एक रेंडर विशेषता है जो निष्पादित विशेषता के समान काम करती है। ये सभी विशेषताएँ एक वेबपेज के आईडी पहचानकर्ता के आधार पर काम करती हैं।

निम्नलिखित उपलब्ध विशेषताओं के विभिन्न स्तर हैं।

  • @all - यह पूरे घटक को अपडेट करेगा।

  • @none - यह आपके किसी भी घटक को अपडेट नहीं करेगा।

  • @this - यह केवल अनुरोध करने वाले घटक को अपडेट करेगा।

  • @from - यह उस फॉर्म को अपडेट करेगा जिसमें अनुरोध डेटा है।

  • @region - यह वेबपेज के एक विशिष्ट क्षेत्र को अपडेट करेगा।

अन्य a4j टैग

अब तक, हमने रिचफेसेस एप्लिकेशन के बारे में वैचारिक गुणों पर चर्चा की है। इस खंड में, हम उनके बारे में हाथों पर उदाहरणों के साथ विस्तार से जानेंगे।

<A4j: AJAX>

यह उन प्रमुख घटकों में से एक है जो रिचफेसेस प्रदान करता है। यह और कुछ नहीं बल्कि JSF2.0 f: AJAX टैग का एक विस्तारित हिस्सा है। जब भी कोई जेएस घटना वेबपृष्ठों में होती है, तो यह टैग AJAX अनुरोध को ट्रिगर करता है। निम्नलिखित उदाहरण इस टैग के बारे में अधिक बताते हैं। वेबपेज फ़ोल्डर के नीचे एक "xhtml" पेज बनाएं और इसे "a4jAJAXExample.xhtml" नाम दें। फिर, निम्नलिखित कोड का पेस्ट करें।

<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">   
   
   <h:head>   
      <title>a4j:AJAX Tag Example</title>   
   </h:head>   

   <h:body>  
      <h:form id = "form"> 
         <h:inputText value = "#{managedBean.message}"> 
            <a4j:AJAX render = "ShowMessage" /> 
         </h:inputText> 
         
         <h:outputText value = "#{managedBean.message}" id = "ShowMessage" 
            style = "animation-duration"/> 
      </h:form> 
   </h:body> 
   
</html>

वेबपृष्ठ से जानकारी प्राप्त करने के लिए हमें एक प्रबंधित बीन बनाने की भी आवश्यकता है। आगे बढ़ो और स्रोत पैकेज निर्देशिका के तहत एक जावा वर्ग बनाएं। निम्नलिखित हैmanagedbean.java कक्षा का कोड।

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      this.message = message;   
   }   
}

दोनों फ़ाइलों को सहेजें और चलाएं, जो ब्राउज़र में निम्न आउटपुट प्राप्त करेगा।

<A4j: param>

a4j: परम एक च का विस्तार है: परम टैग। इसका उपयोग किसी प्रॉपर्टी या इंस्टेंस वैरिएबल के मान को असाइन करने के लिए किया जाता है। यह टैग स्थायी रूप से उदाहरण चर के मान को निर्दिष्ट करने में सक्षम है। निम्नलिखित "a4jparamExample.html" कोड है।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Param tag example</title> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/> 
   </h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:panelGrid columns = "2"> 
            <a4j:commandButton value = "TutorialsPoint" render = "rep"> 
               <a4j:param value = "Tutorials point" assignTo = "#{managedBean.message}" /> 
            </a4j:commandButton> 
  
            <a4j:commandButton value = "RichFace Tutorials" render = "rep"> 
               <a4j:param value = "RichFace Tutorials" assignTo = "#{managedBean.message}" /> 
            </a4j:commandButton> 
         </h:panelGrid> 
         <br /> 
         
         <h:outputText id = "rep" value = "Selected Name:#{managedBean.message}" /> 
      </h:form> 
   </h:body> 
   
</html>

निम्नलिखित इसी बीन क्लास कोड है।

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("This method is getting called with"+message); 
      
      // we have added this line in order to check how the AJAX call 
      // happens to the class methods without any direct communication  
      this.message = message;   
   }   
}

आगे बढ़ो और फ़ाइल चलाएँ। ब्राउज़र में आउटपुट निम्न है।

अब, सर्वर कंसोल में आपको निम्न आउटपुट दिखाई देगा, जो यह साबित करता है कि रन समय में इंस्टेंस चर सेट करने के लिए xhtml फ़ाइल प्रबंधित बीन के साथ संचार कर रही है।

<A4j: CommandButton>

हमने पहले ही अपने पिछले उदाहरण में कमांड बटन टैग का उपयोग किया है। इसका उपयोग एक एक्सएचटीएमएल पेज के अंदर एक बटन बनाने के लिए किया जाता है, जो विशिष्ट अनुरोध को संसाधित करने के लिए AJAX इंजन के साथ उत्पन्न और संचार करेगा। यह एक इनपुट लेता है और उसी को प्रोसेस करता है और वेब ब्राउजर में आउटपुट देता है।

पिछले उदाहरण में, हमने दो बटन बनाए हैं - "TutorialsPoint" और "RichFace Tutorials"। हमारा कमांड बटन टैग आंतरिक रूप से प्रबंधित बीन के साथ संचार करता है और आवश्यक उदाहरण चर सेट करता है। यह मूल्य प्रदान करने के लिए भी जिम्मेदार है।

<A4j: commandLink>

कमांड लिंक जेएसएफ 2.0 के <h: कमांडलिंक> घटक की तरह काम करता है। जब भी कमांड लिंक JS क्लिक इवेंट पर काम करता है, कमांड बटन सबमिट-आधारित AJAX अनुरोध करता है। कमांड बटन और कमांड लिंक में केवल यही अंतर है। उदाहरण के बाद आप टैग को बेहतर तरीके से समझने में मदद करेंगे। "A4jCommandLink.xhtml" फ़ाइल बनाएं और उसमें निम्न कोड पेस्ट करें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Example of command Link</title> 
   </h:head> 
    
   <h:body> 
      <h:form id = "form">
         <h:panelGrid columns = "3"> 
            <h:outputText value = "Name:" /> 
            <h:inputText value = "#{managedBean.message}" /> 
             <a4j:commandLink value = "Click Me" render = "out" execute = "@form" /> 
         </h:panelGrid> 
      </h:form> 
      <br /> 
      
      <a4j:outputPanel id = "out"> 
         <h:outputText value = "Welcome to #{managedBean.message} !" /> 
      </a4j:outputPanel> 
   </h:body> 
   
</html>

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

<A4j: outputPanel>

आउटपुट पैनल HTML पेज की अवधि के रूप में काम करता है। यह व्यक्तिगत रूप से निर्दिष्ट करने के बजाय एक वेबपेज के विभिन्न घटकों को समूहित करने के लिए उपयोग किया जाता है। पिछले उदाहरण में, हमने इनपुट टेक्स्ट बॉक्स में दिए गए संदेश को प्रदर्शित करने के लिए आउटपुट पैनल का उपयोग किया है। निम्नलिखित आउटपुट पैनल का सिंटैक्स है।

<a4j:outputPanel id = "out"> 
   <h:outputText value = "Welcome to #{managedBean.message} !" /> 
</a4j:outputPanel>

<A4j: क्षेत्र>

यह रिचफेसेस की प्रमुख विशेषता है, जो वेबपेज के कुछ हिस्सों को प्रोसेस करने की अनुमति देता है। इस टैग का उपयोग करते हुए, रिच वृक्षों में आंशिक वृक्ष प्रसंस्करण होता है। इसका उपयोग मुख्य रूप से प्रतिपादन प्रक्रिया को बढ़ाने के लिए किया जाता है। निम्नलिखित उदाहरण आपको इसे विस्तार से समझने में मदद करेंगे। कृपया निम्न कोड का उपयोग करके एक "a4jregionExample.xhtml" फ़ाइल बनाएं।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j" >  
   
   <h:head> 
      <title>Region Example</title>       
   </h:head> 
    
   <h:body> 
      <h:form> 
         <h:inputText value = "#{managedBean.message}"/> 
         <h:inputText value = "#{managedBean.job}"/> 
         <a4j:commandLink id = "one" value = "one"/> 
         
         <a4j:region> 
            <h:inputText value = "#{managedBean.message}"/> 
            <a4j:commandLink id = "two" value = "two"/> 
         </a4j:region>
      </h:form>  
   </h:body> 
   
</html>

इस एक्सएचटीएमएल पेज के साथ, कृपया हमारे द्वारा प्रबंधित प्रबंधित करें तदनुसार।

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;  
   String job; 
      public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("setMessage method is getting called with--"+message); 
      this.message = message;   
   } 
   public String getJob() { 
      return job; 
   } 
   public void setJob(String job) { 
      System.out.println("setJob method is getting called with--"+job); 
      this.job = job; 
   } 
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

जब भी कमांड लिंक "वन" पर क्लिक किया जाता है, यह पूरे फॉर्म को प्रोसेस करेगा, हालांकि, जब हम कमांड लिंक "दो" पर क्लिक करते हैं, केवल संदेश इंस्टेंस को संसाधित किया जाएगा क्योंकि यह एक क्षेत्र टैग के भीतर संलग्न है। इसी तरह, यदि हम दूसरे क्षेत्र के टैग में कमांड लिंक 'एक' को संलग्न करते हैं, तो यह केवल पहले दो इनपुट मापदंडों को संसाधित करेगा। सर्वर कंसोल का स्क्रीनशॉट निम्न है, जब भी कमांड लिंक "दो" पर क्लिक किया जाता है।

जब भी कमांड लिंक "वन" पर क्लिक किया जाएगा, निम्नलिखित आउटपुट होगा।

<A4j: दोहराने>

रिपीट टैग ठीक वैसे ही काम करता है जैसा कि <ui: दोहराएँ> जेएसएफ का टैग। यह वेबपेज में एक सूची पर पुनरावृति करने में मदद करता है। "A4jRepeat.xhtml" फ़ाइल के निम्नलिखित उदाहरण में, हम अपने प्रबंधित बीन वर्ग की एक सूची के माध्यम से पुनरावृत्ति कर रहे हैं।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:panelGrid columns = "1" style = "width: 640px"> 
            <a4j:outputPanel id = "panel" layout = "block"> 
               <a4j:repeat       value = "#{managedBean.subjectList}" var = "sub"> 
                  <li> 
                     <h:outputText value = "#{sub}"/> 
                  </li> 
               </a4j:repeat> 
            </a4j:outputPanel> 
         </h:panelGrid> 
      </h:form> 
   </h:body> 
   
</html>

एक बार जब आप ब्राउज़र में इस विशिष्ट फ़ाइल को चलाते हैं, तो आपको निम्न आउटपुट मिलेगा।

<A4j: स्थिति>

जैसा कि नाम से पता चलता है, यह टैग तब भी उपयोगी होता है जब आप फ्रंट-एंड में अपने AJAX अनुरोध की स्थिति प्रदर्शित करना चाहते हैं। आप अपनी पसंद के अनुसार एक सामान्य पाठ संदेश या gif या छवि-आधारित स्थिति शामिल कर सकते हैं। निम्नलिखित जैसे एक छोटे से अनुप्रयोग के लिए, आपको फ्रंट-एंड में स्थिति की एक झलक मिलेगी, हालांकि, जब भी आप एक जटिल AJAX अनुरोध चला रहे हैं, यह स्थिति बहुत अधिक दिखाई देती है। कृपया नीचे दिखाए अनुसार "a4jregionExample.xhtml" को संशोधित करें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Region Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form> 
         <a4j:status startText = "Working..." /> 
            <h:inputText value = "#{managedBean.message}"/> 
            <h:inputText value = "#{managedBean.job}"/> 
            <a4j:commandLink id = "one" value = "one"/>
            
            <a4j:region> 
               <h:inputText value = "#{managedBean.message}"/> 
               <a4j:commandLink id = "two" value = "two"/> 
            </a4j:region> 
            
         <a4j:status startText = "Done" /> 
      </h:form>  
   </h:body> 
   
</html>

जब भी आप इस एप्लिकेशन को चला रहे होते हैं, तो आप दो स्थितियों "कार्य ..." और "पूर्ण" की झलक देख सकते हैं। जब भी अनुरोध पूरा हो जाएगा ये स्थितियां अपने आप गायब हो जाएंगी।

<A4j: शामिल> / <a4j: KeepAlive>

शामिल करें और KeepAlive, दोनों टैग्स RichFaces 3.0 में पेश किए गए थे, लेकिन RichFaces 4 में इन टैगों को हटा दिया गया था क्योंकि इन कार्यक्षमताओं को फेसलेट्स में उपयोग किए गए विभिन्न अन्य टैग्स जैसे <ui: शामिल> और <ui: सम्मिलित करें> का उपयोग करके आसानी से प्राप्त किया जा सकता है। जैसा कि नाम से पता चलता है, एक पृष्ठ को दूसरे में शामिल करने के लिए शामिल किया गया था और JSF पृष्ठ के साथ प्रबंधित बीन सहयोगी के दायरे को नियंत्रित करने के लिए KeepAlive पेश किया गया था। यह किसी भी सॉफ्टवेयर एपीआई के अद्यतन संस्करण का उपयोग करने और व्यावसायिक लक्ष्यों को प्राप्त करने के लिए <UI> घटक और "एनोटेशन" कार्यान्वयन का उपयोग करने की सिफारिश की जाती है।

<A4j: लॉग>

जैसा कि नाम से पता चलता है, यह a4j घटक वेब ब्राउज़र में लॉगिंग जानकारी उत्पन्न करने में मदद करता है। निम्नलिखित उदाहरण इस टैग के बारे में अधिक बताते हैं। निम्नलिखित तरीके से "a4jregionExample.xhtml" फ़ाइल संपादित करें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Region Example</title> 
   </h:head> 
    
   <h:body>
      <h:form> 
         <a4j:status startText = "Working..." /> 
            <h:inputText value = "#{managedBean.message}"/> 
            <h:inputText value = "#{managedBean.job}"/> 
            <a4j:commandLink id = "one" value = "one"/> 
            
            <a4j:region> 
               <h:inputText value = "#{managedBean.message}"/> 
               <a4j:commandLink id = "two" value = "two"/> 
            </a4j:region> 
            
            <a4j:log></a4j:log> 
         <a4j:status startText = "Done" /> 
      </h:form>  
   </h:body>
   
</html>

अब ब्राउज़र में उपरोक्त कोड चलाएं और निम्नलिखित आउटपुट होगा। a4j: लॉग जब भी आवश्यक हो सभी स्तरों के आवश्यक लॉग उत्पन्न करेगा।

<A4j: jsFunction>

यह रिचफेसेस की सबसे उन्नत विशेषता है, जहाँ बिना किसी जावास्क्रिप्ट कोड के एक स्वचालित JS फ़ंक्शन बनाया जा सकता है। सीडीके किसी भी जेएस घटना के आधार पर एक स्वचालित जावास्क्रिप्ट कोड उत्पन्न करेगा।

निम्नलिखित उदाहरण में, हम एक जावास्क्रिप्ट फ़ंक्शन बना रहे हैं, जिसे तब भी कहा जाएगा जब हम एक निर्दिष्ट मूल्य पर होवर करेंगे।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Example of JS Function</title> 
   </h:head> 
    
   <h:body> 
      <table width = "500" border = "1"> 
         <tbody> 
            <tr> 
               <td>
                  <span onmouseover = "showMySkill('core java,J2EE')" 
                     onmouseout = "showMySkill('')">BackEnd developer</span>
               </td> 
               <td>
                  <span onmouseover = "showMySkill('DB,RDBMS,unix')" 
                     onmouseout = "showMySkill('')">Database Admin</span>
               </td> 
               <td>
                  <span onmouseover = "showMySkill(
                     'JS frameworks,html,java scripts')" 
                     onmouseout = "showMySkill('')">Front End Developer</span>
               </td> 
            </tr> 
            <tr> 
               <td colspan = "3">You need to know: 
                  <b><h:outputText id = "showSkillset" value = "#{managedBean.message}"/></b>
               </td> 
            </tr> 
         </tbody> 
      </table> 
      
      <h:form id = "form"> 
         <a4j:jsFunction name = "showMySkill" render = "showSkillset"> 
            <a4j:param name = "name" assignTo = "#{managedBean.message}" /> 
         </a4j:jsFunction> 
      </h:form> 
   </h:body> 
</html>

उपरोक्त कोड ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा। JS ईवेंट के आधार पर, CDK "showMySkill ()" नाम की विधि को ओवरराइड करेगा और आवश्यक मान ब्राउज़र में प्रिंट किए जाएंगे।

<A4j: AJAXListener>

इस टैग का उपयोग तब किया जाता है जब आप किसी विशेष श्रोता को ब्राउज़र पर परिणाम देने से ठीक पहले निष्पादित करना चाहते हैं। यह टैग रिचफेसेस 4 में उपलब्ध नहीं है क्योंकि उसी कार्यक्षमता में उपलब्ध है , जहाँ आप किसी भी JS घटना के होने पर AJAX अनुरोध कर सकते हैं। यद्यपि अद्यतन सॉफ़्टवेयर संस्करण का उपयोग करना उचित है, यदि आप अभी भी रिचफे 3 का उपयोग कर रहे हैं, तो आप निम्न तरीके से इस टैग का उपयोग कर सकते हैं।

<rich:panel> 
   <f:facet name = "header">Using a4j:actionListener</f:facet> 
   <a4j:commandButton value="Submit" reRender = "#{AJAXBean.areas}"> 
      <a4j:AJAXListener binding = "#{AJAXBean.renderAreasListener}"/> 
   </a4j:commandButton> 
</rich:panel>

उपरोक्त उदाहरण में, "सबमिट" बटन पर क्लिक करने पर, एक जेएस घटना बनाई जाएगी, जो बीन क्लास के अंदर लागू किए गए "क्षेत्रों" विधि को कॉल करेगी और इसके परिणामस्वरूप परिणाम प्रस्तुत किया जाएगा।

रिचफेस को एक केंद्रीकृत तरीके से रिच स्किन कहा जाता है। त्वचा पुरानी सीएसएस फाइलों का एक उच्च स्तरीय कार्यान्वयन है, जो कि बैक-एंड डेवलपर के लिए वेबसाइट के लुक और फील को नियंत्रित करने के लिए अधिक सुविधाजनक है। कुछ अंतर्निहित खाल उपलब्ध हैं, जिन्हें आपकी पसंद के अनुसार अनुकूलित किया जा सकता है।

अंतर्निहित त्वचा

RichFaces घटक जार फ़ाइल में उपलब्ध कई अंतर्निहित खाल हैं। निम्नलिखित कुछ अंतर्निहित समृद्ध त्वचा उपलब्ध हैं।

  • Default
  • Plain
  • emeraldTown
  • blueSky
  • wine
  • japanCherry
  • ruby
  • classic
  • deepMarine
  • NULL

निम्नलिखित उदाहरण में, हम "क्लासिक" त्वचा को लागू करेंगे। उपरोक्त किसी भी खाल को लागू करना बहुत आसान है। आगे बढ़ने से पहले, कृपया नीचे दिए गए कोड की लाइन का उपयोग करके "web.xml" फ़ाइल में त्वचा जोड़ें। हम उपरोक्त सूची में से अपनी पसंद की कोई भी त्वचा जोड़ सकते हैं। हमें बस उपयुक्त त्वचा के नाम के साथ <param-value> टैग को संशोधित करने की आवश्यकता है।

<context-param>   
   <param-name>org.richfaces.skin</param-name>
   <param-value>classic</param-value>   
</context-param>

इसे जोड़ने के बाद, कृपया "SkinExample.xhtml" फ़ाइल बनाएं और इसमें कोड की निम्न पंक्ति जोड़ें।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <f:view>   
      <h:head>   
         <title>Rich Faces Built in Skin</title>   
      </h:head>   
      
      <h:body>   
         <h:form>   
            <rich:panel style = "width:60%"> 
               <rich:tabPanel switchType = "AJAX"> 
                  <rich:tab header = "Name"> 
                     Tutorials Point 
                  </rich:tab> 
                  
                  <rich:tab header = "Features"> 
                     Best Place to learn 
                  </rich:tab> 
               </rich:tabPanel> 
            </rich:panel>           
         </h:form>   
      </h:body>
      
   </f:view>   
</ui:composition>

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

उपरोक्त उदाहरण में, <अमीर: पैनल> एक पैनल बनाता है जहां हम <अमीर: टैब> का उपयोग करके विभिन्न टैब बना रहे हैं। <अमीर: tabPanel स्विच टाइप = "AJAX"> उपयोग किए गए टैब का AJAX संक्रमण प्रदान करता है।

त्वचा को बनाना / संशोधित करना

त्वचा सीएसएस डिज़ाइन के एक विस्तारित संस्करण के अलावा और कुछ नहीं है, जो रनटाइम पर वेबपेज पर लागू होगी। पिछले अनुभाग में, हमने त्वचा की कुछ बुनियादी अंतर्निहित कार्यक्षमता सीखी। इस खंड में, हम अपनी त्वचा बनाएंगे या मौजूदा त्वचा को संशोधित करेंगे। रिचफेसेस में त्वचा को निम्नलिखित तीन स्तरों पर अनुकूलित किया जा सकता है।

Skin property file- सभी खाल "rechfaces-a4j-4.5.17.Final" जार फ़ाइल के तहत उल्लिखित विभिन्न संपत्ति फ़ाइलों के माध्यम से उत्पन्न होती हैं। हम सभी को एक ही प्रॉपर्टी फाइल बनाने और अपने सोर्स फोल्डर के नीचे रखने और उसकी प्रॉपर्टी को एडिट करने की जरूरत है। हमें वेबसाइट में अपनी नई स्किन प्रॉपर्टी के अनुसार अपने "web.xml" को बदलने की जरूरत है।

Component style sheet - पसंद की नई सीएसएस फ़ाइल को लागू करें और आवेदन में इसका उपयोग करें।

Overwrite style class - एक एक्सएचटीएमएल फ़ाइल में शैली के गुणों का सीधे उल्लेख करके शैली को ओवरराइट कर सकते हैं।

चलिए, हम एक उदाहरण पर विचार करते हैं। हम अपनी पिछली "क्लासिक" त्वचा को अनुकूलित करेंगे। "स्रोत" पैकेज के अंदर एक संपत्ति फ़ाइल बनाएँ और इसे "custom.skin.properties" नाम दें। इस संपत्ति फ़ाइल की प्रविष्टियां निम्नलिखित हैं जिन्हें ऊपर उल्लेखित जार फ़ाइल में उपलब्ध अन्य संपत्ति फाइलों से कॉपी किया गया था।

#Colors 
headerBackgroundColor = #black 
headerGradientColor = #DF5858 
headerTextColor = #FFFFFF 
headerWeightFont = bold 

generalBackgroundColor = #f1f1f1 
generalTextColor = #000000 
generalSizeFont = 10px 
generalFamilyFont = Arial, Verdana, sans-serif 

controlTextColor = #000000 
controlBackgroundColor = #ffffff 
additionalBackgroundColor = #F9E4E4 

shadowBackgroundColor = #000000 
shadowOpacity = 1 
panelBorderColor = #C0C0C0 
subBorderColor = #ffffff 

tabBackgroundColor = #EDAEAE 
tabDisabledTextColor = #C47979 
trimColor = #F7C4C4 
tipBackgroundColor = #FAE6B0 
tipBorderColor = #E5973E 

selectControlColor = #FF9409 
generalLinkColor = #CF0000 
hoverLinkColor = #FF0000 
visitedLinkColor = #CF0000 

# Fonts
headerSizeFont = 11px 
headerFamilyFont = Arial, Verdana, sans-serif 
tabSizeFont = 11 
tabFamilyFont = Arial, Verdana, sans-serif 
buttonSizeFont = 11 
CHAPTER 11 ■ SKINS 223 
buttonFamilyFont = Arial, Verdana, sans-serif 

tableBackgroundColor = #FFFFFF 
tableFooterBackgroundColor = #cccccc 
tableSubfooterBackgroundColor = #f1f1f1 
tableBorderColor = #C0C0C0 
tableBorderWidth = 1px 

#Calendar colors 
calendarWeekBackgroundColor = #f5f5f5 
calendarHolidaysBackgroundColor = #FFF1F1 
calendarHolidaysTextColor = #980808 
calendarCurrentBackgroundColor = #808080 
calendarCurrentTextColor = #ffffff 
calendarSpecBackgroundColor = #f1f1f1 
calendarSpecTextColor = #000000 

warningColor = #FFE6E6 
warningBackgroundColor = #FF0000 
editorBackgroundColor = #F1F1F1 
editBackgroundColor = #FEFFDA 

#Gradients 
Gradient Type = plain

कौशल स्तर के आधार पर, हम इस गुण फ़ाइल में किसी भी विशेषता को बदल सकते हैं। हम नई शैली वर्ग जोड़ सकते हैं या मौजूदा को संपादित कर सकते हैं। एक बार जब हम नई संपत्ति फ़ाइल के निर्माण के साथ हो जाते हैं, तो यह "web.xml" फ़ाइल में समान जोड़ने का समय है। निम्नलिखित "web.xml" की प्रविष्टि है, जो हमारी त्वचा को इंगित करना चाहिए।

<context-param> 
   <param-name>org.richfaces.skin</param-name> 
   <param-value>custom</param-value> 
</context-param>

Note - सुनिश्चित करें कि नई संपत्ति फ़ाइल स्रोत निर्देशिका के अंदर मौजूद है, अन्यथा यह "NoClassFound अपवाद" कहकर एक रनटाइम त्रुटि फेंक देगा।

आगे बढ़ो और "SkinExample.xhtml" नाम की पिछली फ़ाइल चलाएं। निम्नलिखित ब्राउज़र में आउटपुट होगा, जहां हम यह देख पाएंगे कि वेबसाइट का पूरा लुक और अहसास बदलकर "रूबी" हो गया है क्योंकि रूबी.प्रोपरेट्स फ़ाइल से एक नई प्रॉपर्टी फाइल कॉपी की गई थी।

रनटाइम पर त्वचा को बदलना

इस उदाहरण में, हम समय के साथ त्वचा को बदल देंगे। निम्नलिखित की तरह एक त्वचा वर्ग बनाएँ।

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.RequestScoped;  

@ManagedBean   
@RequestScoped 

public class skinBean {  
   private String skin;  
   public skinBean() { 
      this.skin="plane"; 
   }
   public String getSkin() { 
      return skin; 
   } 
   public void setSkin(String skin) { 
      this.skin = skin; 
   } 
}

फिर रनटाइम पर त्वचा के नाम को पॉप्युलेट करने के लिए "web.xml" फाइल को निम्नानुसार बदलें।

<context-param>   
   <param-name>org.richfaces.skin</param-name>
   <param-value>#{skinBean.skin}</param-value>
</context-param>

ऐसा करने के बाद, हमें JSF एप्लिकेशन की कॉन्फ़िगरेशन फ़ाइलों को बदलने की आवश्यकता है। फ़ाइलें वेब-इन्फो फ़ोल्डर के तहत स्थित हो सकती हैं। इसमें निम्नलिखित बीन संपत्ति जोड़ें।

<managed-bean> 
   <managed-bean-name>skinBean</managed-bean-name> 
   <managed-bean-class>SkinBean</managed-bean-class>> 
   <managed-bean-scope>session</managed-bean-scope> 
   
   <managed-property> 
      <property-name>skin</property-name> 
      <value>plain</value> 
   </managed-property> 
</managed-bean>

निम्नलिखित xhtml फ़ाइल कोड है।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j" 
   xmlns:f = "http://java.sun.com/jsf/core" 
   xmlns:rich = "http://richfaces.org/rich">
   
   <h:head> 
      <title>TODO supply a title</title> 
   </h:head> 
   
   <h:body> 
      <h:form> 
         <div style = "display: block; float: left"> 
            <h:selectOneRadio value = "#{skinBean.skin}" border = "0" 
               layout = "pageDirection" title = "Changing skin" style = "font-size: 8; 
               font-family: comic" onchange = "submit()"> 
               <f:selectItem itemLabel = "plain" itemValue = "plain" /> 
               <f:selectItem itemLabel = "emeraldTown" itemValue = "emeraldTown" /> 
               <f:selectItem itemLabel = "blueSky" itemValue = "blueSky" /> 
               <f:selectItem itemLabel = "wine" itemValue = "wine" /> 
               <f:selectItem itemLabel = "japanCherry" itemValue = "japanCherry" /> 
               <f:selectItem itemLabel = "ruby" itemValue = "ruby" /> 
               <f:selectItem itemLabel = "deepMarine" itemValue = "deepMarine" /> 
            </h:selectOneRadio> 
         </div> 
         
         <div style = "display: block; float: left"> 
            <rich:panel > 
               <rich:panelMenu style = "font-family: monospace; font-size: 12;"> 
                  Changing skin in runtime 
               </rich:panelMenu> 
  
               <rich:panelMenu  style = "font-family: monospace; font-size: 12;"> 
                  This is a result of the modification "blueSky" skin 
               </rich:panelMenu> 
            </rich:panel> 
         </div> 
      </h:form> 
   </h:body> 
   
</html>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।

उपरोक्त उदाहरण में, शुरू में हम "सादे" का चयन कर रहे हैं, इसलिए यह सादे की ओर इशारा करता है। एक बार जब आप रेडियो बटन के माध्यम से प्रचार करते हैं, तो यह तदनुसार रंग बदल देगा।

अब तक हमने "स्किन" नामक एक नई कार्यक्षमता के साथ रिचफेस के विभिन्न AJAX घटकों के बारे में बहुत कुछ सीखा है। इस अध्याय में, हम विभिन्न "रिच" घटकों को जानेंगे जो रिचफेसेस आधुनिक वेब एप्लिकेशन विकसित करने के लिए प्रदान करता है। "रिचफेसेस" द्वारा प्रदान किए गए विभिन्न इनपुट घटक निम्नलिखित हैं।

<अमीर: inplaceInput>

अमीर inplaceInput एक सामान्य इनपुट टेक्स्ट बॉक्स के बजाय एक संपादन योग्य टेक्स्ट बॉक्स बनाने का अवसर प्रदान करता है। निम्नलिखित उदाहरण में, हम इस घटक का उपयोग करके एक संपादन योग्य टेक्स्ट बॉक्स बनाएंगे। एक एक्सएचटीएमएल फ़ाइल बनाएँ और इसे "richinplaceInput.xhtml" नाम दें। उस फ़ाइल में निम्नलिखित कोड लिखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>TODO supply a title</title> 
   </h:head> 
    
   <h:body> 
      <f:view></f:view>   
      <h:form>   
         <rich:inplaceInput  value = "#{managedBean.message}"   
            defaultLabel = "Enter Your Name"/> 
      </h:form>  
   </h:body>
   
</html>

इस फाइल को सेव करें और रन करें। निम्नलिखित ब्राउज़र में आउटपुट होगा।

आगे बढ़ें और उस टेक्स्ट बॉक्स में अपनी पसंद का कुछ भी लिखें और एंटर करें। यह टैग इनलाइन संपादन विकल्प भी प्रदान करता है। संपादन के बाद आउटपुट दिया जाएगा।

<अमीर: inplaceSelect>

यह रिचफेसेस द्वारा प्रदान किया गया एक और इनपुट मार्कअप है, जहां उपयोगकर्ता ड्रॉपडाउन सूची से एक इनपुट मूल्य का चयन कर सकता है, जो प्रकृति में इनलाइन और संपादन योग्य भी है। हमें आंतरिक बीन वर्ग से ड्रॉपडाउन को आबाद करने की आवश्यकता है। कृपया "xhtml" फ़ाइल बनाएं और इसे "richinplaceSelectExample.xhtml" नाम दें। उस फ़ाइल में कोड का निम्नलिखित टुकड़ा रखें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>TODO supply a title</title>
   </h:head> 
    
   <h:body> 
      <h:form> 
         <rich:inplaceSelect value = "#{subject.subjectName}" defaultLabel = "Click to Select Country">
            <f:selectItems value = "#{subject.SubJectList()}"></f:selectItems>   
         </rich:inplaceSelect> 
      </h:form>     
   </h:body>
   
</html>

उपरोक्त उदाहरण में, हम बैकएंड से ड्रॉपडाउन विकल्पों को आबाद करेंगे। यहाँ “subject.java” नाम की बीन क्लास है।

import java.util.ArrayList; 
import java.util.List; 
import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ManagedProperty; 
import javax.faces.bean.RequestScoped;   

@ManagedBean 
@RequestScoped 

public class Subject { 
   String SubjectName;  
   public Subject() { 
   }  
   public Subject(String SubjectName) { 
      this.SubjectName = SubjectName; 
   } 
   public List<String> SubJectList() {  
      //this list to be rendered
      ArrayList<String> list = new ArrayList<>();   
      
      list.add("JAVA");   
      list.add("DOTNET");   
      list.add("COBOL");   
      list.add("AJAX");   
      list.add("JAVA SCRIPT");   
      return list;   
   }    
   public String getSubjectName() { 
      return SubjectName; 
   } 
   public void setSubjectName(String SubjectName) { 
      this.SubjectName = SubjectName; 
   } 
}

सभी विषय नाम जिसे हम सूची से गुजर रहे हैं, ड्रॉपडाउन मेनू के अंदर दिखाया जाएगा। इस एप्लिकेशन को चलाने के बाद आउटपुट होगा।

<अमीर: SuggestionBox>

<अमीर: सुझाव टेक्स्ट बॉक्स में दिए गए इनपुट के आधार पर उपयोगकर्ता को सुझाव प्रदान करने के लिए प्रयोग किया जाता है। यह टैग आंतरिक रूप से जेएस घटना बनाता है और बैकएंड से सुझाव प्रदान करने के लिए आवश्यक istener वर्ग को आमंत्रित करता है। दुर्भाग्य से, यह सुझाव बॉक्स और कॉम्बोबॉक्स, दोनों को एक अलग टैग में जोड़ दिया जाता है, जिसे रिचफेसेस 4 में "<रिच: ऑटोकम्प्लीट>" कहा जाता है, हालांकि, यदि आप रिचफे 3 का उपयोग कर रहे हैं, तो आप नीचे दिखाए गए अनुसार इस टैग का उपयोग कर सकते हैं।

<h:inputText id = "city" value = "#{capitalsBean.capital}" /> 
<rich:suggestionbox for = "city" var = "result" 
   suggestionAction = "#{capitalsBean.autocomplete}"> 
   
   <h:column> 
      <h:outputText value = "#{result.name}" /> 
   </h:column> 
</rich:suggestionbox>

जहाँ "राजधानियाँ" एक जावा वर्ग होगी जिसमें विभिन्न पैरामीटर और श्रोता वर्ग होगा जिसका नाम "स्वत: पूर्ण" होगा, जो रनटाइम के दौरान "कैपिटल" उदाहरण चर का मान निर्धारित करेगा और पसंद का आवश्यक आउटपुट प्रदान करेगा। यह इस टैग का उपयोग करने के बजाय RichFaces 4 "स्वतः पूर्ण" का उपयोग करने के लिए अत्यधिक अनुशंसित है क्योंकि डिज़ाइनर इस टैग का समर्थन नहीं कर रहे हैं।

<अमीर: बता गया>

<अमीर: comboBox> ठीक इसी तरह से काम करता है <अमीर: सुझाव बॉक्स>, हालांकि, श्रोता वर्ग को कॉल करने के बजाय, यह टैग क्लाइंट ब्राउज़र में कुछ सुझावों को पूर्व-प्रदान करता है जो एक दूसरे के साथ बातचीत करते हैं और वांछित आउटपुट प्रदान करते हैं। जैसे <अमीर: sugegstionBox>, इस फीचर को नए वर्जन में भी एक और टैग के साथ डेप्रिसिएट किया गया है, जिसे निम्नलिखित कोड में वर्णित "<अमीर: ऑटोकम्प्लीट>" के रूप में जाना जाता है।

एक अलग फ़ाइल बनाएं और इसे "richAutoComplete.xhtml" नाम दें। उस फ़ाइल में निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:form id = "form"> 
            <rich:autocomplete mode = "cachedAJAX" minChars = "2" 
            autocompleteMethod = "#{autoComplete.SubJectList()}" /> 
         </h:form> 
      </h:form> 
   </h:body>
   
</html>

उपरोक्त उदाहरण में, हम रिचफेसेस की स्वतः पूर्ण सुविधा के माध्यम से विषय सूची को पॉप्युलेट कर रहे हैं। एक और जावा वर्ग बनाएं और इसे "autoComplete.java" नाम दें।

import java.util.ArrayList; 
import java.util.List; 
import javax.faces.bean.ManagedBean; 
import javax.faces.bean.RequestScoped;  

@ManagedBean 
@RequestScoped 

public class autoComplete { 
   public autoComplete(){} 
   private List<String> autoCompleteList=new ArrayList<>(); 
   
   public List<String> SubJectList() {   
      //ArrayList<String> list = new ArrayList<>();   
      autoCompleteList.add("JAVA");   
      autoCompleteList.add("DOTNET");   
      autoCompleteList.add("COBOL");   
      autoCompleteList.add("AJAX");   
      autoCompleteList.add("JAVA SCRIPT");   
      return autoCompleteList;   
   }   
   public List<String> getAutoCompleteList() {
      return autoCompleteList; 
   }  
   public void setAutoCompleteList(List<String> autoCompleteList) { 
      this.autoCompleteList = autoCompleteList; 
   } 
}

उपरोक्त फ़ाइल बीन क्लास के रूप में कार्य कर रही है और सब्जेक्टलिस्ट () विधि है, जो वास्तव में ब्राउज़र की प्रतिक्रिया का प्रतिपादन कर रही है। <SuggestionBox>, <ComboBox> टैग में हमें श्रोता वर्ग को लागू करने की आवश्यकता है, हालांकि, <स्वतः पूर्ण> टैग के मामले में श्रोता वर्ग की इस रचना को स्वचालित किया गया है, जो डेवलपर के लिए आसान है। कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

<अमीर: inputNumberSlider>

यह एक बहुत ही सरल टैग है जो डेवलपर को संख्यात्मक अंतराल के आधार पर एक संख्यात्मक स्लाइडर बार बनाने में मदद करता है। "InputNumberSlider.xhtml" फ़ाइल बनाएं और इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form>   
         <h:outputText value = "Slide Bar example"></h:outputText>   
         <rich:inputNumberSlider    
            minValue = "1"   
            maxValue = "10"   
            showArrows = "false"   
            showTooltip = "false"   
            step = "1">   
         </rich:inputNumberSlider>   
      </h:form>  
   </h:body>
   
</html>

उपरोक्त उदाहरण में, विशेषताएँ बहुत अधिक वर्णनात्मक हैं। कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

<अमीर: कैलेंडर>

जैसा कि नाम से पता चलता है कि यह टैग ब्राउज़र में एक कैलेंडर बनाने में मदद करेगा। एक अलग फ़ाइल बनाएँ और इसे "richCalendar.xhtml" नाम दें। इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form>   
         <h1>Calendar</h1>   
         <rich:calendar value = "#{calendarBean.selectedDate}"   
            locale = "#{calendarBean.locale}"   
            popup = "#{calendarBean.popup}"   
            datePattern = "#{calendar.pattern}"   
            style = "width:200px">
         </rich:calendar>   
      </h:form> 
   </h:body>
   
</html>

हमें तिथि, स्थान, तिथि पैटर्न, आदि जैसे सभी कैलेंडर मान रखने के लिए "CalendarBean.java" नामक एक और वर्ग बनाने की आवश्यकता है, इसके बाद "CalendarBean.java" का कोड है।

import java.text.DateFormat; 
import java.util.Date; 
import java.util.Locale; 
  
import javax.faces.event.ValueChangeEvent; 
  
public class CalendarBean { 
   private static final String[] WEEK_DAY_LABELS = new String[] { 
      "Sun *", "Mon +", "Tue +", "Wed +", "Thu +", "Fri +", "Sat *" }; 
   
   private Locale locale; 
   private boolean popup; 
   private boolean readonly; 
   private boolean showInput; 
   private boolean enableManualInput;     
   private String pattern; 
   private Date currentDate; 
   private Date selectedDate; 
   private String jointPoint; 
   private String direction; 
   private String boundary; 
   private boolean useCustomDayLabels; 
  
   public Locale getLocale() { 
      return locale; 
   }
   public void setLocale(Locale locale) { 
      this.locale = locale; 
   } 
   public boolean isPopup() { 
      return popup; 
   } 
   public void setPopup(boolean popup) { 
      this.popup = popup; 
   } 
   public String getPattern() { 
      return pattern; 
   } 
   public void setPattern(String pattern) { 
      this.pattern = pattern; 
   } 
   public CalendarBean() { 
      locale = Locale.US; 
      popup = true; 
      pattern = "MMM d, yyyy"; 
      jointPoint = "bottomleft"; 
      direction = "bottomright"; 
      readonly = true; 
      enableManualInput = false; 
      showInput = true; 
      boundary = "inactive"; 
   } 
   public boolean isShowInput() { 
      return showInput;
   } 
   public void setShowInput(boolean showInput) { 
      this.showInput = showInput; 
   } 
   public boolean isEnableManualInput() { 
      return enableManualInput; 
   } 
   public void setEnableManualInput(boolean enableManualInput) { 
      this.enableManualInput = enableManualInput; 
   } 
   public boolean isReadonly() { 
      return readonly; 
   } 
   public void setReadonly(boolean readonly) { 
      this.readonly = readonly; 
   } 
   public void selectLocale(ValueChangeEvent event) { 
      String tLocale = (String) event.getNewValue(); 
      if (tLocale != null) { 
         String lang = tLocale.substring(0, 2); 
         String country = tLocale.substring(3); 
         locale = new Locale(lang, country, ""); 
      } 
   } 
   public boolean isUseCustomDayLabels() { 
      return useCustomDayLabels; 
   } 
   public void setUseCustomDayLabels(boolean useCustomDayLabels) { 
      this.useCustomDayLabels = useCustomDayLabels; 
   } 
   public Object getWeekDayLabelsShort() { 
      if (isUseCustomDayLabels()) { 
         return WEEK_DAY_LABELS; 
      } else { 
         return null; 
      } 
   } 
   public String getCurrentDateAsText() { 
      Date currentDate = getCurrentDate(); 
      if (currentDate ! =  null) { 
         return DateFormat.getDateInstance(DateFormat.FULL).format(currentDate); 
      } 
      return null; 
   } 
   public Date getCurrentDate() { 
      return currentDate; 
   } 
   public void setCurrentDate(Date currentDate) { 
      this.currentDate = currentDate; 
   } 
   public Date getSelectedDate() { 
      return selectedDate; 
   } 
   public void setSelectedDate(Date selectedDate) { 
      this.selectedDate = selectedDate; 
   } 
   public String getJointPoint() { 
      return jointPoint; 
   } 
   public void setJointPoint(String jointPoint) { 
      this.jointPoint = jointPoint; 
   } 
   public void selectJointPoint(ValueChangeEvent event) { 
      jointPoint = (String) event.getNewValue(); 
   } 
   public String getDirection() { 
      return direction; 
   } 
   public void setDirection(String direction) { 
      this.direction = direction; 
   } 
   public void selectDirection(ValueChangeEvent event) { 
      direction = (String) event.getNewValue(); 
   } 
   public String getBoundary() { 
      return boundary; 
   } 
   public void setBoundary(String boundary) { 
      this.boundary = boundary; 
   } 
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

<अमीर: InputNumberSpinner>

यह टैग डेवलपर को बीन की एक आवृत्ति को दर्शाने के लिए एक स्पिनर बनाने में मदद करता है। निम्नलिखित एक उदाहरण है जो आपको स्पिनर टैग को विस्तार से समझने में मदद करेगा। कृपया एक अलग एक्सएचटीएमएल फाइल बनाएं और इसे "InputNumberSpinner.xhtml" नाम दें और इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Number Slider Example</title> 
   </h:head>
   
   <h:body> 
      <h:form>   
         <h:outputText value = "Select a Date"></h:outputText>
         <br/>
         <br/>   
         
         <rich:inputNumberSpinner   
            minValue = "1"   
            maxValue = "31"   
            step = "1">   
         </rich:inputNumberSpinner>  
      </h:form>   
   </h:body>
   
</html>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

पिछले अध्याय में, हमने विभिन्न इनपुट फ़ील्ड या टैग के बारे में सीखा है जो उपयोगकर्ता को ब्राउज़र के माध्यम से इनपुट प्रदान करने में मदद करते हैं। इस अध्याय में, हम RichFaces द्वारा प्रदान किए गए विभिन्न आउटपुट घटकों के बारे में जानेंगे।

<अमीर: कक्ष>

हमारे पिछले कुछ उदाहरणों में, हम पहले ही पैनल टैग में आ चुके हैं। <समृद्ध: पैनल> वेबपृष्ठ के अंदर एक आयताकार क्षेत्र बनाता है, जिसमें कोई भी जानकारी हो सकती है। आप एक पैनल के अंदर अन्य पैनल, चित्र और किसी भी अन्य समृद्ध घटक को शामिल कर सकते हैं।

निम्नलिखित उदाहरण में, हम पसंद के अनुसार एक कस्टम पैनल बनाएंगे और हम "हेडर" विशेषता का उपयोग करके अपने पैनल को एक हेडर प्रदान करेंगे। कृपया एक एक्सएचटीएमएल फ़ाइल बनाएं और इसे "richPanelExamlple.xhtml" नाम दें। इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Panel Example</title> 
   </h:head> 
   
   <h:body> 
      <rich:panel header = "RichFace Tutorials " style = "font-size: 500px; 
         align-items:center; background-color: activecaption"> 
         
         RichFace Tutorials Presented by TutorialsPoint.com.      
      </rich:panel> 
   </h:body>
</html>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

<अमीर: simpleTogglePanel>

SimpleTogglePanel डेवलपर्स को एक गतिशील तरीके से पैनल के बदलाव को बदलने का अवसर प्रदान करता है। हालाँकि, RichFaces 4 में, इस टैग को दबा दिया गया है। JBoss ने <अमीर: togglePanel>, <rich: tab>, और <rich: tabPanel> जैसे उन्नत टैग पेश किए हैं। अधिक सुविधाओं और कार्यात्मकताओं के लिए रिचफेस टैग के अपडेट किए गए संस्करण का उपयोग करने की सिफारिश की गई है। यदि आप अभी भी RichFaces 3 का उपयोग कर रहे हैं, तो आप निम्न टैग का उपयोग कर सकते हैं।

<ui:composition xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:f = "http://java.sun.com/jsf/core" 
   xmlns:a4j = "http://richfaces.org/a4j" 
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <rich:simpleTogglePanel switchType = "client" label = "SimpleToggle"> 
      The simple example of SimpleToggle tag 
   </rich:simpleTogglePanel>    
</ui:composition>

<अमीर: tabPanel>

यह टैग डेवलपर्स को एक पैनल के अंदर अलग टैब बनाने में मदद करता है। हमने इस टैग का उपयोग अपने स्किन चैप्टर में किया है, जहाँ हमने दूसरे पैनल के अंदर दो अलग-अलग टैग बनाए हैं। निम्नलिखित कोड यह वर्णन करेगा कि हम <अमीर: tabPanel> का उपयोग कैसे करते हैं।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <f:view>   
      <h:head>   
         <title>Rich Faces Tab Example</title>   
      </h:head>   
      
      <h:body>   
         <h:form>   
            <rich:panel style = "width:60%"> 
               
               <rich:tabPanel switchType = "AJAX"> 
                  <rich:tab header = "Name"> 
                     Tutorials Point----This is Tab Number 1 
                  </rich:tab> 
                  
                  <rich:tab header = "Features"> 
                     Best Place to learn -------This is Tab Number 2 
                  </rich:tab> 
               </rich:tabPanel> 
            </rich:panel>  
            
         </h:form>   
      </h:body> 
      
   </f:view>   
</ui:composition>

इस उदाहरण में, हमने "नाम" और "सुविधाएँ" नामक अलग-अलग हेडर के साथ दो टैब बनाए हैं। ये दो टैग <अमीर: पैनल> के अंदर बनाए जाएंगे। उपरोक्त कोड निम्न आउटपुट देगा।

<अमीर: panelBar>

SimpleToggleBar की तरह, यह डेवलपर्स को कुछ JS इवेंट के आधार पर वर्टिकल टॉगल को लागू करने की अनुमति देता है। यह टैग रिचफेसेस 4 में भी दबा हुआ है। हालांकि, आप इसे नीचे दिखाए गए अनुसार उपयोग कर सकते हैं यदि आप रिचफेसेस 3.0 का उपयोग कर रहे हैं। ।

<ui:composition xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:f = "http://java.sun.com/jsf/core" 
   xmlns:a4j = "http://richfaces.org/a4j" 
   xmlns:rich = "http://richfaces.org/rich">  
   
   <rich:panelBar height = "400" width = "500"> 
      <rich:panelBarItem   label = "Toggle1”> 
         First vertical toggle 
      </rich:panelBarItem> 
      
      <rich:panelBarItem  label = ”Toggle2”> 
         Second Vertical Toggle 
      </rich:panelBarItem> 
   </rich:panelBar >
   
</ ui:composition >

रिचफेसेस 4 में, एक ही कार्यक्षमता को <रिच: पैनलमेनु> टैग का उपयोग करके लागू किया गया है।

<अमीर: टैब>

हम पहले से ही इस टैग से परिचित हैं। <अमीर: tabPanel> के उदाहरण में, हमने इस टैग के साथ अलग-अलग टैब बनाए हैं। निम्नलिखित उदाहरण में, हमने दो टैग बनाए हैं।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <f:view>   
      <h:head>   
         <title>Rich Faces Tab Example</title>   
      </h:head>   
      
      <h:body>   
         <h:form>   
            
            <rich:panel style = "width:60%"> 
               <rich:tabPanel switchType = "AJAX"> 
                  <rich:tab header = "Name"> 
                     Tutorials Point----This is Tab Number 1 
                  </rich:tab> 
                  
                  <rich:tab header = "Features"> 
                     Best Place to learn -------This is Tab Number 2 
                  </rich:tab> 
               </rich:tabPanel> 
            </rich:panel> 
            
         </h:form>   
      </h:body> 
      
   </f:view>   
</ui:composition>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

<अमीर: panelMenu>

पैनल मेनू डेवलपर्स को एक पैनल क्षेत्र के अंदर एक ऊर्ध्वाधर ड्रॉपडाउन टॉगल बनाने में मदद करता है। निम्नलिखित उदाहरण हमें इस टैग को बेहतर ढंग से समझने में मदद करेंगे। "RichPanelMenu.xhtml" फ़ाइल बनाएं और उसके अंदर कोड का निम्नलिखित टुकड़ा रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Panel Menu example</title> 
   </h:head> 
    
   <h:body> 
      <h:form id = "form"> 
         <h:panelGrid columns = "2" columnClasses = "cols,cols" width = "400"> 
            <rich:panelMenu style = "width:200px"> 
               
               <rich:panelMenuGroup label = "Group 1"> 
                  <rich:panelMenuItem label = "Database" action = "#{managedBean.subjectList}"> 
                     <f:param name = "current" value = "DB"/> 
                  </rich:panelMenuItem> 
                  
                  <rich:panelMenuItem label = "Oracle" action = "#{managedBean.subjectList}"> 
                     <f:param name = "current" value = "Oracle"/>  
                  </rich:panelMenuItem> 
                  
                  <rich:panelMenuItem label = "JAVA" action = "#{managedBean.subjectList}"> 
                     <f:param name = "current" value = "JAVA"/> 
                  </rich:panelMenuItem> 
               </rich:panelMenuGroup>
               
            </rich:panelMenu> 
         </h:panelGrid> 
      </h:form> 
   </h:body>
   
</html>

जैसा कि उपरोक्त उदाहरण में देखा गया है, पैनलमेनु कुछ अन्य संबद्ध टैग के साथ आता है जो एक अलग तरीके से मदद करता है। <पैनलग्रेड> पैनल के अंदर एक ग्रिड बनाने में मदद करता है। <panelMenuGroup> उन विभिन्न घटकों को समूह बनाने में मदद करता है जिन्हें हम पॉप्युलेट करने जा रहे हैं। <पैनलमेनुइटेम> वह वास्तविक आइटम है जो ब्राउज़र को प्रदान किया जाएगा। "एक्शन" विशेषता का उपयोग करके, आप चयनित आइटम के आधार पर विभिन्न एक्शन विधियों को कॉल कर सकते हैं। "लेबल" विशेषता का उपयोग फ्रंट-एंड में मान को पॉप्युलेट करने के लिए किया जाता है और निर्दिष्ट एक्शन क्लास को कॉल करने के बाद प्रदान किए गए मान को बैक-एंड पर संसाधित किया जाएगा।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

<अमीर: TogglePanel>

यह टैग विभिन्न आउटपुट को रेंडर करने के लिए उपयोग किया जाता है जिसे टॉगल कंट्रोल विधि का उपयोग करके स्विच या टॉगल किया जा सकता है। इस टॉगल नियंत्रण विधि को लागू या अनुकूलित किया जा सकता है। निम्नलिखित उदाहरण में, हम इस पद्धति को लागू करेंगे।

एक एक्सएचटीएमएल फ़ाइल बनाएँ और इसे "richTogglePanel.xhtml" नाम दें। इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Rich Toggle Panel Example</title> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/> 
   </h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <rich:togglePanel id = "panel1" activeItem = "item1" 
            itemChangeListener = "#{panelMenuBean.updateCurrent}"> 
            
            <rich:togglePanelItem name = "item1"> 
               <p>Content of the toggle 1</p> 
            </rich0:togglePanelItem> 
            
            <rich:togglePanelItem name = "item2"> 
                <p>Content of the toggle 2</p> 
            </rich:togglePanelItem> 
         </rich:togglePanel> 
            
         <a4j:outputPanel id = "tabs" layout = "block"> 
            <a4j:outputPanel layout = "block" styleClass = "tabDiv"> 
               <rich:toggleControl event = "click" targetPanel = "panel1" targetItem = "item1" /> 
               <a4j:commandButton value = "Toggle1"/> 
            </a4j:outputPanel> 
            
            <a4j:outputPanel layout = "block" styleClass = "tabDiv"> 
               <rich:toggleControl event = "click" targetPanel = "panel1" targetItem = "item2" /> 
               <a4j:commandButton value = "Toggle2"/> 
            </a4j:outputPanel> 
         </a4j:outputPanel>
         
      </h:form> 
   </h:body>
   
</html>

हमें वेबसाइट के संक्रमण को नियंत्रित करने के लिए बीन क्लास बनाने की भी आवश्यकता है। निम्नलिखित की तरह “MenuBean.java” वर्ग बनाएँ।

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ViewScoped; 
import org.richfaces.event.ItemChangeEvent; 
  
@ManagedBean 
@ViewScoped 

public class MenuBean { 
   private String current; 
   private boolean singleMode; 
  
   public boolean isSingleMode() { 
      return singleMode; 
   } 
   public void setSingleMode(boolean singleMode) { 
      this.singleMode = singleMode; 
   } 
   public String getCurrent() { 
      return this.current; 
   } 
   public void setCurrent(String current) { 
      this.current = current; 
   } 
   public void updateCurrent(ItemChangeEvent event) { 
      setCurrent(event.getNewItemName()); 
   }
}

उपरोक्त कोड ब्राउज़र में निम्न आउटपुट देगा।

उपर्युक्त उदाहरण में, उपयोगकर्ता द्वारा क्लिक किए गए बटन के आधार पर वेबपृष्ठ की सामग्री को बदल दिया जाएगा। "UpdateCurrent ()" वह विधि है जो JS घटना सामग्री को संभालती है और चलते-फिरते वेबसाइट की सामग्री सेट करती है।

<अमीर: टूलबार>

टूलबार का उपयोग पैनल में एक क्षैतिज पट्टी बनाने के लिए किया जाता है। इसका उपयोग वेबपेज में शीर्ष स्तर मेनू बनाने के लिए किया जाता है। निम्नलिखित उदाहरण में, हम वेबपेज में इस टैग का उपयोग करना सीखेंगे। एक "एक्सएचटीएमएल" फ़ाइल बनाएं और इसे "टूलबार.एक्सएचएमएल" नाम दें। इसमें निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>ToolBar Example</title> 
   </h:head> 
   
   <h:body> 
      <rich:panel> 
         <rich:toolbar height = "26" itemSeparator = "grid"> 
            <rich:toolbarGroup location = "left"> 
               <h:commandButton styleClass = "barsearchbutton" 
                  onclick = "return false;" value = "TAB" /> 
            </rich:toolbarGroup> 
            
            <rich:toolbarGroup location = "left"> 
               <h:commandButton styleClass = "barsearchbutton" 
                  onclick = "return false;" value = "TAB2" /> 
            </rich:toolbarGroup> 
            
            <rich:toolbarGroup location = "left"> 
               <h:commandButton styleClass = "barsearchbutton" 
                  onclick = "return false;" value = "TAB3" /> 
            </rich:toolbarGroup> 
         </rich:toolbar>
 
      </rich:panel> 
   </h:body>
   
</html>

उपरोक्त कोड ब्राउज़र में निम्न आउटपुट देगा।

उपरोक्त उदाहरण में, <toolbarGroup> टैग का उपयोग विभिन्न प्रकार के टूल को समूहीकृत करने के लिए किया जाता है। कितने भी समूह बनाए जा सकते हैं। स्थान वेबपृष्ठ की स्थिति प्रदान करता है, जहां बटन रखा जाएगा।

<अमीर: विभाजक>

जैसा कि नाम से पता चलता है, इसका उपयोग वेबपेज पर विभिन्न घटकों को अलग करने के लिए किया जाता है। इस टैग को RichFaces 4 में दबा दिया गया है, हालाँकि, यदि आप अभी भी RichFaces 3 का उपयोग कर रहे हैं, तो आप निम्न टैग का उपयोग कर सकते हैं।

<rich:separator lineType = "beveled" height = "8" width = "75%" align = "center"/>
<p>Here is more examples of different line types:</p> 

<rich:separator height = "2" lineType = "dotted"/><br/> 
<rich:separator height = "2" lineType = "dashed"/><br/> 
<rich:separator height = "4" lineType = "double"/><br/>
<rich:separator height = "2" lineType = "solid"/><br/>

उपरोक्त उदाहरण में, लाइन टाइप वह विशेषता है जो हमें उस विभाजक के प्रकार को निर्धारित करने में मदद करती है जिसका हम उपयोग करना चाहते हैं। ये सभी विभाजक नाम प्रकृति में बहुत अधिक आत्म-वर्णनात्मक हैं।

<अमीर: स्पेसर>

स्पेसर एक स्व-वर्णित टैग है जो डेवलपर को दो घटकों के बीच एक स्थान प्रदान करने में मदद करता है। यह टैग अन्य टैग्स के साथ-साथ RichFaces4 में भी दबा हुआ है, हालाँकि, यदि आप RichFaces 3 का उपयोग कर रहे हैं, तो आप निम्न कोड का उपयोग कर सकते हैं।

<rich:spacer width = "1" height = "5" title = "Here is a spacer..."/>

<अमीर: modalPanel>

मोडल पैनल का इस्तेमाल चलते-फिरते पॉप-अप को दिखाने के लिए किया जाता है। RichFaces 4 में, मोडल पैनल टैग को बदल दिया गया हैpopupPanel। निम्नलिखित उदाहरण में, हम देखेंगे कि यह कैसे काम करता है। एक एक्सएचटीएमएल फ़ाइल बनाएं और इसे "पॉपिंगअप पीएक्सएचटीएमएल" नाम दें। इसमें निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>ModalPanel and popupPanel</title> 
   </h:head> 
    
   <h:body> 
      <h:form> 
         <h:commandButton value = "Click ME">  
            <rich:componentControl target = "popup" operation = "show" /> 
         </h:commandButton> 
         
         <rich:popupPanel id = "popup" modal = "true" autosized = "false" 
            resizeable = "false"> 
            
            Hey !!!
            How are you? 
         </rich:popupPanel> 
      </h:form>   
   </h:body>
   
</html>

उपरोक्त उदाहरण "ClickMe" बटन क्लिक होने पर निम्न आउटपुट उत्पन्न करेगा।

पिछले अध्यायों में, हमने विभिन्न इनपुट और आउटपुट घटकों के बारे में सीखा है। इस अध्याय में, हम सीखेंगे कि वेबसाइट में विभिन्न डेटा संरचनाओं के माध्यम से पुनरावृति कैसे करें।

<अमीर: datatable>

इस टैग का उपयोग वेबसाइट में परिणाम के रूप में एक तालिका प्रस्तुत करने के लिए किया जाता है। निम्नलिखित उदाहरण में, हम प्रो-दक्षता स्तर के साथ एक विषय तालिका प्रस्तुत करेंगे।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <h:head>   
      <title>Rich Data Table</title>   
   </h:head>   
    
   <h:body>   
      <h:form>   
         <rich:dataTable value = "#{subject.subjectListObj}" var = "record" >   
            <f:facet name = "header">   
               <h:outputText value = "My Profile" />   
            </f:facet>   
            
            <rich:column>   
               <f:facet name = "header">Subject Name</f:facet>   
               <h:outputText value = "#{record.subjectName}"/> 
            </rich:column> 
            
            <rich:column>    
               <f:facet name = "header">efficiency Level</f:facet>   
               <h:outputText value = "#{record.efficiency}"/> 
            </rich:column>   
         </rich:dataTable>
      </h:form>   
   </h:body>
   
</html>

हमें सूची को रेंडर करने के लिए अपने विषय को बदलने की जरूरत है। निम्नलिखित विषय का एक उदाहरण है। जावा।

import java.util.ArrayList; 
import java.util.List; 
import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ManagedProperty; 
import javax.faces.bean.RequestScoped;   

@ManagedBean 
@RequestScoped 

public class Subject { 
   String SubjectName; 
   private String efficiency; 
   
   private List<Subject> subjectListObj=new ArrayList<>(); 
      public Subject() { 
   }  
   public Subject(String SubjectName,String efficiency ) { 
      this.SubjectName = SubjectName; 
      this.efficiency= efficiency; 
   } 
   public String getSubjectName() { 
      return SubjectName; 
   } 
   public void setSubjectName(String SubjectName) { 
      this.SubjectName = SubjectName; 
   } 
   public List<Subject> getSubjectListObj() {
      subjectListObj.add(new Subject("JAVA","Expert"));   
      subjectListObj.add(new Subject("DOTNET","NA"));   
      subjectListObj.add(new Subject("JAVA Script","Expert"));   
      subjectListObj.add(new Subject("Web Service","Expert"));   
      subjectListObj.add(new Subject("Consulting","Expert"));   
      return subjectListObj; 
   } 
   public void setSubjectListObj(List<Subject> subjectListObj) { 
      this.subjectListObj = subjectListObj; 
   } 
   public String getEfficiency() { 
      return efficiency; 
   } 
   public void setEfficiency(String efficiency) { 
      this.efficiency = efficiency; 
   } 
}

उपरोक्त उदाहरण ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

<अमीर: dataDefinitionList>

यह एक मॉडल से डेटा परिभाषा उत्पन्न करने के लिए उपयोग किया जाने वाला टैग है। इस टैग को JBoss द्वारा RichFaces 4 के आविष्कार के बाद से समर्थित नहीं किया गया है। यदि आप अभी भी RichFaces 3 का उपयोग कर रहे हैं, तो आप इस टैग का उपयोग निम्न तरीके से कर सकते हैं।

<rich:dataDefinitionList var = "car" value = "#{dataTableScrollerBean.allCars}" 
   rows = "5" first = "4" title = "Cars">  
   
   <f:facet name = "term">  
      <h:outputText value = "#{car.make} #{car.model}"></h:outputText>  
   </f:facet>  
   
   <h:outputText value = "Price:" styleClass = "label"></h:outputText>  
   <h:outputText value = "#{car.price}" /><br/>  
   <h:outputText value = "Mileage:" styleClass = "label"></h:outputText>  
   <h:outputText value = "#{car.mileage}" /><br/>  
</rich:dataDefinitionList>

उपरोक्त उदाहरण में, "dataTableScrollerBean" एक जावा वर्ग है जिसका उपयोग कार के विभिन्न मूल्यों को उत्पन्न करने के लिए किया जाता है। यह पिछले टैग के समान है जहां हमने <datitable> टैग का उपयोग करके ऑब्जेक्ट वैल्यू का एक गुच्छा पॉपुलेट किया है।

<अमीर: dataOrderedList>

RichFaces 4, RichFaces 3 से एक विस्तृत मॉडरेशन के साथ आया है। <dataOrderedList> एक टैग है जिसका उपयोग ऑर्डर किए गए तरीके से सूची प्रस्तुत करने के लिए किया जाता है। यह भी RichFaces 4 में दबा हुआ है क्योंकि किसी ऑब्जेक्ट या सूची का ऑर्डर जावा में किए जाने पर अधिक आसान और कम समय लेने वाला है। यदि आपका एप्लिकेशन रिचफेसेस 3 का उपयोग करता है, तो आप इस टैग का उपयोग निम्न तरीके से कर सकते हैं।

<rich:panel style = "width:500px"> 
   <f:facet name = "header"> 
      Using rich:dataOrderedList 
   </f:facet> 
   
   <rich:dataOrderedList value = "#{airlinesBean.airlines}" var = "air"> 
      #{air.name}, #{air.code} 
   </rich:dataOrderedList> 
</rich:panel>

उपरोक्त उदाहरण में, "AirlinesBean" एक Java बीन क्लास है, जिसमें "AirlinesBean ()" नाम की एक विधि है। यह विधि "वायु" प्रकार की वस्तु देती है। बाद में, हम एक टेबल प्रारूप में विभिन्न गुणों को पॉप्युलेट करने के लिए इस एयर ऑब्जेक्ट का उपयोग कर सकते हैं।

<अमीर: DataList>

जैसा कि टैग नाम से पता चलता है, इस टैग का उपयोग ब्राउज़र में एक अनियंत्रित सूची को प्रस्तुत करने के लिए किया जाएगा। हालांकि, <ऑर्डरलिस्ट> की तरह यह टैग भी रिचफेसेस के नवीनतम संस्करण में दबा हुआ है। हम निम्नलिखित तरीके से आसानी से ब्राउज़र में एक सूची प्रस्तुत कर सकते हैं <a4j: दोहराएँ> और <अमीर: dataTable> टैग।

<a4j:repeat value = "#{managedBean.subjectList}" var = "sub"> 
   <h:outputText value = "#{sub}"/>   
</a4j:repeat>

उपरोक्त उदाहरण में, हम एक सूची दे रहे हैं, जो "सब्जेक्टलिस्ट ()" नामक विधि का एक आउटपुट है। यदि आपका एप्लिकेशन रिचफेसेस 3 में बनाया गया है, तो आप इस टैग का उपयोग इस प्रकार कर सकते हैं।

<rich:panel style = "width:500px"> 
   <f:facet name = "header"> 
      Using rich:dataList 
   </f:facet> 
   
   <rich:dataList value = "#{airlinesBean.airlines}" var = "air"> 
      #{air.name}, #{air.code} 
   </rich:dataList>
</rich:panel>

<अमीर: DataGrid>

<Datitable> टैग का उपयोग करके आप किसी सूची को तालिका के रूप में प्रस्तुत कर पाएंगे, हालाँकि, <dataGrid> आपको किसी वस्तु या सूची को प्रस्तुत करने में मदद करेगा। <अमीर: datatable> के पिछले उदाहरण में, बस एक्सएचटीएमएल पेज को निम्नानुसार बदलें और देखें कि उसी का आउटपुट क्या है।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <h:head>   
      <title>Rich Data Table</title>   
   </h:head>   
    
   <h:body>   
      <h:form>   
         <rich:panel> 
            <rich:dataGrid value = "#{subject.subjectListObj}" var = "record" 
               columns = "2" elements = "4" first = "1" >   
               
               <f:facet name = "header">   
                  <h:outputText value = "My Profile" />   
               </f:facet>   
               
               <rich:panel> 
                  <rich:column>   
                     <f:facet name = "header">Subject Name</f:facet>   
                     <h:outputText value = "#{record.subjectName}"/> 
                  </rich:column>  
                  
                  <rich:column>    
                     <f:facet name = "header">efficiency Level</f:facet>   
                     <h:outputText value = "#{record.efficiency}"/> 
                  </rich:column> 
               </rich:panel> 
               
            </rich:dataGrid>  
         </rich:panel> 
      </h:form>   
   </h:body> 
   
</html>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा।

<अमीर: datascroller>

यह टैग तालिका डेटा को पॉप्युलेट करते समय एक स्क्रॉल बार बनाने में मदद करता है। यह जेएसएफ की पेजिंग कार्यक्षमता के समान है। निम्नलिखित तरीके से पिछले डेटाटेबल उदाहरण को संशोधित करें।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <h:head>
      <title>Rich Data Table</title>   
   </h:head>   
    
   <h:body>   
      <h:form>   
         <rich:dataTable value = "#{subject.subjectListObj}" var = "record" 
            rows = "3" id = "MyTable">   
            
            <f:facet name = "header">   
               <h:outputText value = "My Profile"/>   
            </f:facet>   
            
            <rich:column>   
               <f:facet name = "header">Subject Name</f:facet>   
               <h:outputText value = "#{record.subjectName}"/> 
            </rich:column> 
            
            <rich:column>    
               <f:facet name = "header">efficiency Level</f:facet>   
               <h:outputText value = "#{record.efficiency}"/> 
            </rich:column>   
         </rich:dataTable> 
         
         <rich:dataScroller for = "MyTable" maxPages = "3">   
            <f:facet name = "first">   
               <h:outputText value = "1" />   
            </f:facet>   
            
            <f:facet name = "last">   
               <h:outputText value = "eof" />   
            </f:facet>   
         </rich:dataScroller> 
      </h:form>   
   </h:body>
   
</html>

उपरोक्त उदाहरण में, आप अपनी शैली को एक अच्छे रूप और महसूस के लिए जोड़ सकते हैं। हमने अलग-अलग पहलू वाले अलग-अलग <dataScroller> टैग लागू किए हैं। निम्नलिखित उपरोक्त फ़ाइल का आउटपुट होगा। तालिका और डेटा स्क्रोलर को सिंक्रनाइज़ करने के लिए शैली सरासर विशेषता को अपडेट करें।

इस अध्याय में, हम RichFaces Technology द्वारा प्रदत्त विभिन्न चयन घटकों के बारे में जानेंगे।

<अमीर: Picklist>

इस टैग का उपयोग करके, हम पॉपुलेटेड सूची से एक मान का चयन कर सकते हैं। यह हमें एक सूची घटक को दूसरी सूची में जोड़ने और हटाने की भी अनुमति देता है। निम्नलिखित उदाहरण दर्शाता है कि यह कैसे काम करता है। आगे बढ़ें और एक एक्सएचटीएमएल फ़ाइल बनाएं और इसे "pickListExample.xhtml" नाम दें और इसमें निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns  =  "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>PickList Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form>   
         <h:outputText value  =  "Pick List Example"/>
         <br/>
         <br/>      
         
         <rich:pickList value = "#{managedBean.subjectList}"   
            sourceCaption = "SubjectList"   
            targetCaption = "Selected Subject"   
            listWidth = "170px"   
            listHeight = "120px"       
            orderable = "true">   
            
            <f:selectItems value = "#{managedBean.subjectList}" 
               itemValue = "#{subject}" itemLabel = "#{subject.subjectName}"/>   
         </rich:pickList>  
      </h:form>
   </h:body> 
   
</html>

हमें xHTML फ़ाइल में सूची घटकों को पॉप्युलेट करने के लिए अपने प्रबंधित बीन.जवा फ़ाइल को संशोधित करना होगा। निम्नलिखित हमारे संशोधित जावा फ़ाइल का स्नैपशॉट है।

import java.util.Arrays; 
import java.util.List; 
import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;  
   String job; 
   private List<String> SubjectList = Arrays.asList(
      "Richface","AJAX","JAVA","JSF","DOTNET","python"); 
   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("setMessage method is getting called with--"+message); 
      this.message = message;   
   } 
   public String getJob() { 
      return job; 
   } 
   public void setJob(String job) { 
      System.out.println("setJob method is getting called with--"+job); 
      this.job = job; 
   } 
   public List<String> getSubjectList() { 
      return SubjectList;
   }  
   public void setSubjectList(List<String> SubjectList) { 
      this.SubjectList = SubjectList; 
   } 
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देगा। पिकलिस्ट टैग की "वैल्यू" विशेषता बीन क्लास के "getSubjectList ()" के अलावा कुछ भी नहीं है। "आइटमवैल्यू" ऑब्जेक्ट क्लास का संक्षिप्त नाम है और संबंधित "आइटमलेबेल" उदाहरण का नाम है। इस उदाहरण में, हमारा पिकलिस्ट टैग स्वचालित रूप से "sourceCaption" और "targetCaption" नामक दो अलग-अलग सूचियाँ बनाता है। लक्ष्य सूची में चयन आदेश को बनाए रखने के लिए गुणकारी आदेश का उपयोग किया जाता है।

<अमीर: orderingList>

इस टैग का उपयोग किसी सूची को संपूर्ण रूप में प्रस्तुत करने के लिए किया जाता है। <orderList> स्वचालित रूप से सूची के माध्यम से प्रचार करने के लिए फ़ंक्शन जैसे कुछ बटन प्रदान करेगा और यह चयनित आइटम को ऑर्डर करने में मदद करता है। निम्नलिखित उदाहरण में, हम "OrderingListExample.xhtml" के लिए निम्न कोड का उपयोग करके एक ऑर्डरिंगलिस्ट बनाएंगे।

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>OrderingList Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form>   
         <h:outputText value = "ordering List Example"/><br/><br/>
         <rich:orderingList value = "#{managedBean.subjectList}"  
            itemValue = "#{subject}" 
            itemLabel = "#{subject.subjectName}" >   
         </rich:orderingList>  
      </h:form>    
   </h:body> 
   
</html>

हमें अपनी बीन क्लास को बदलने की आवश्यकता नहीं है क्योंकि हम अलग-अलग प्रतिनिधित्व के लिए अलग-अलग टैग का उपयोग करके एक ही सूची को फिर से आबाद कर रहे हैं। पिछले उदाहरण की तरह, यहां भी मान विशेषता "getSubjectList ()" से आने वाली पूरी सूची को रखती है। "ItemValue" और "itemLabel" क्रमशः ऑब्जेक्ट क्लास और संबंधित उदाहरण चर का मान रखता है।

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।

<अमीर: ListShuttle>

ListShuttle टैग RichFaces 3 में उपलब्ध है। यह एक सूची के माध्यम से प्रचार करने में मदद करता है और उसी मूल्य को दूसरे में डालता है। RichFaces 4 में, इस टैग को दबा दिया गया है क्योंकि उसी कार्यक्षमता को <अमीर: pickList> नामक एक अन्य नए टैग द्वारा प्राप्त किया जा सकता है। यदि आप RichFaces 3.0 का उपयोग कर रहे हैं, तो आप निम्न तरीके से इस टैग का उपयोग कर सकते हैं।

<rich:listShuttle sourceValue = "#{toolBar.freeItems}" 
   targetValue = "#{toolBar.items}" var = "items" listsHeight = "150" 
   sourceListWidth = "130" targetListWidth = "130" 
   sourceCaptionLabel = "Available Items" 
   targetCaptionLabel = "Currently Active Items" 
   converter = "listShuttleconverter">  
   
   <rich:column width = "18">  
      <h:graphicImage value = "#{items.iconURI}"></h:graphicImage> 
   </rich:column> 
   
   <rich:column> 
      <h:outputText value = "#{items.label}"></h:outputText> 
   </rich:column> 
   
   <a4j:support event = "onlistchanged" reRender = "toolBar" /> 
   <a4j:support event = "onorderchanged" reRender = "toolBar" /> 
</rich:listShuttle>

इस टैग का उपयोग करने के बजाय पिकलिस्ट का उपयोग करना बहुत सुविधाजनक है, क्योंकि कोड की केवल दो पंक्तियों को लिखकर पिकलिस्ट का उपयोग करके समान कार्यक्षमता प्राप्त की जा सकती है।

RichFaces मेनू प्रकार मार्कअप बनाने के लिए उपयोग किए जाने वाले टैग का एक विस्तृत संस्करण प्रदान करता है। इस अध्याय में, हम पुराने लोगों के साथ कुछ नई सुविधाएँ सीखेंगे जिनके उपयोग से हम ब्राउज़र में एक मेनू को आसानी से प्रस्तुत कर सकते हैं।

<अमीर: dropDownMenu>

इस टैग का उपयोग करके, डेवलपर एक ड्रॉपडाउन मेनू बना सकता है। यह टैग किसी वेबसाइट का हेडर बनाने के लिए उपयोगी है। निम्नलिखित उदाहरण में, हम सीखेंगे कि इस टैग का उपयोग व्यावहारिक जीवन में कैसे किया जाए। एक फ़ाइल बनाएँ और इसे "DropDownList.xhtml" नाम दें। इसके अंदर निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form> 
         <rich:toolbar>   
            <rich:dropDownMenu>   
               <f:facet name = "label">   
                  <h:outputText value = "File" />   
               </f:facet>       
                  
               <rich:menuItem label = "New" />   
               <rich:menuItem label = "Open File..." />   
               <rich:menuItem label = "Close" />   
               <rich:menuItem label = "Close All" />
            </rich:dropDownMenu>   
         </rich:toolbar>   
      </h:form> 
   </h:body> 
   
</html>

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

<अमीर: ContextMenu>

यह टैग क्लाइंट साइड पर ईवेंट-आधारित ड्रॉपडाउन उत्पन्न करने के लिए उपयोगी है। यह अपने आप काम नहीं करेगा। उपयोगकर्ताओं को जेएस इवेंट बनाने की आवश्यकता है और फिर यह उसी के अनुसार काम करता है। निम्नलिखित उदाहरण में, हम रेंडर छवि बनाएंगे और फिर उपयोगकर्ताओं की प्रतिक्रिया के आधार पर जेएस इवेंट बनाएंगे। निम्नलिखित एक्सएचटीएमएल फ़ाइल है।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>ContextMenu Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form id = "form"> 
         <h:outputScript> 
            //<![CDATA[ 
               function resize(pic, coeff) { 
                  var w  =  Math.round(pic.width * coeff); 
                  var h  =  Math.round(pic.height * coeff); 
                  
                  if (w > 1 && h > 1 && h<1000 && w<1000) { 
                     pic.width  =  w; 
                     pic.heigth  =  h; 
                  } 
               } 
               function enlarge(element){ 
                  resize(element, 1.1); 
               } 
               function decrease(element){ 
                  resize(element, 0.9); 
               } 
            //]]> 
         </h:outputScript> 
         <h:graphicImage value = "http://www.tutorialspoint.com/images/jsf-minilogo.png" 
            id = "pic" style = "border : 5px solid #E4EAEF"/> 
         
         <rich:contextMenu target = "pic" mode = "client" showEvent = "click"> 
            <rich:menuItem label = "Zoom In" onclick = 
               "enlarge(#{rich:element('pic')});" id = "zin"/> 
            <rich:menuItem label = "Zoom Out" 
               onclick = "decrease(#{rich:element('pic')});" id = "zout"/> 
               
        </rich:contextMenu> 
      </h:form> 
   </h:body>
   
</html>

उपरोक्त उदाहरण चलाएं और प्रदान की गई छवि का चयन करें। निम्नलिखित विकल्प "ज़ूम इन" और "ज़ूम आउट" प्रस्तुत किए जाएंगे। उपयुक्त विकल्प पर क्लिक करें और आवश्यक कार्यक्षमता छवि पर लागू होगी। कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

<अमीर: घटक नियंत्रण>

जब भी हम RichFaces वातावरण से किसी अन्य फ़ंक्शन को कॉल करना चाहते हैं, तो यह घटक उपयोगकर्ता के अनुकूल है। इस टैग का उपयोग जावास्क्रिप्ट-आधारित कार्रवाई वर्गों को कॉल करने के लिए किया जाता है। निम्नलिखित उदाहरण दर्शाता है कि इस टैग का उपयोग कैसे किया जा सकता है। एक फ़ाइल बनाएँ और इसे "ComponentsContent.xhtml" फ़ाइल के रूप में नाम दें। इसमें कोड का निम्नलिखित टुकड़ा रखें।

<?xml version = "1.0" encoding = "UTF-8"?> 
<!-- 
   To change this license header, choose License Headers in Project Properties. 
   To change this template file, choose Tools | Templates 
   and open the template in the editor. 
--> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Component Control Example</title>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/> 
   </h:head> 
    
   <h:body> 
      <h:commandButton value = "Call the popup"> 
         <rich:componentControl target = "popup" operation = "show" /> 
      </h:commandButton> 
      <rich:popupPanel id = "popup" modal = "false" autosized = "true" resizeable = "false">
         <f:facet name = "header"> 
            <h:outputText value = "Welcome mesage" /> 
         </f:facet> 
         
         <f:facet name = "controls"> 
            <h:outputLink value = "#" 
               onclick = "#{rich:component('popup')}.hide(); return false;" 
               style = "color: inherit"> 
               
               X 
            </h:outputLink> 
         </f:facet> 
         <p>Welcome to RICH FACE tutorial at tutorialspoint.com</p> 
      </rich:popupPanel> 
   </h:body>
   
</html>

उपरोक्त कोड में, हम एक “popup” का उपयोग करके “onclick ()” फ़ंक्शन को बुला रहे हैं। एक बार जब हम इसे चलाते हैं, तो यह "कॉल पॉपअप" के साथ एक बटन दिखाता है। एक बार जब हम बटन पर क्लिक करते हैं, RichFaces आंतरिक रूप से JS फ़ंक्शन को कॉल करता है और ब्राउज़र में निम्न आउटपुट प्रदान करता है।

इस अध्याय में, हम रिचफेसेस में ट्री प्रोसेसिंग के बारे में जानेंगे। रिचफेसेस एक पेड़ बनाने और हेरफेर करने के लिए सभी आवश्यक घटक प्रदान करते हैं।

<अमीर: treeNode>

इस टैग का उपयोग एक पदानुक्रमित पेड़ बनाने के लिए किया जाता है। प्रत्येक ट्री <ट्रीएनोड> के अंदर प्रदान किया गया नोड ट्री का एक बच्चा नोड होगा। इस टैग का उपयोग एक अन्य टैग के साथ किया जाएगा जिसे <अमीर: पेड़> कहा जाता है। वृक्ष बनाने के लिए हम जो भी उदाहरण चर का उपयोग कर रहे हैं, उन्हें इन तीनों में से किसी एक को लागू करना होगा -org.richfaces.model.TreeNode, org.richfaces.model.TreeDataModel, तथा javax.swing.tree.TreeNode

निम्नलिखित उदाहरण में, हम बैकेंड से <समृद्ध: ट्रीनोड> टैग का उपयोग करके एक पेड़ को आबाद करेंगे।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>TreeNode Example</title> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
   </h:head> 
    
   <h:body> 
      <h:form>   
         <rich:tree value = "#{tree.populateNode}" var = "tree">   
            <rich:treeNode>   
               <rich:treeModelRecursiveAdaptor> 
               </rich:treeModelRecursiveAdaptor>  
               <h:outputText value = "#{tree.data}" />   
            </rich:treeNode>
         </rich:tree>   
      </h:form>   
   </h:body> 

</html>

इसके बाद संबंधित जावा वर्ग लागू होता है “TreeNodeImpl” इंटरफेस।

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   
import org.richfaces.model.TreeNodeImpl;    

@ManagedBean   
@RequestScoped   

public class Tree extends TreeNodeImpl {   
   private Tree stationRoot;   
   private Tree populateNode;   
   private Object data;   
   
   public Tree() {   
      super();   
   }   
   public Tree(boolean leaf, Object data) {   
      super(leaf);   
      this.data = data;   
   }   
   public Object getData() {   
      return data;   
   }   
   public Tree getPopulateNode() {   
      if (populateNode == null) {   
         String[] List_OF_Node = {
            "Frist Node", "Second Node", "Third Node", "Fourth Node", "Fifth Node"};
         stationRoot = new Tree(false, "Example Of Tree");
         
         for (int i = 0; i < List_OF_Node.length; i++) {   
            Tree child = new Tree(true, List_OF_Node[i]);   
            stationRoot.addChild(i, child);   
         }   
         populateNode = new Tree();   
         populateNode.addChild(0, stationRoot);   
      }   
      return populateNode;   
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।

<अमीर: treeModelAdaptor>

यह घटक एक मानचित्र को इनपुट के रूप में लेता है, इसके माध्यम से पुनरावृत्त करता है, और ब्राउज़र में आवश्यक आउटपुट उत्पन्न करता है। जब भी हमें एक पुनरावर्ती मानचित्र को पॉप्युलेट करने की आवश्यकता होती है, हम किसी अन्य टैग का उपयोग कर सकते हैं<rich:recursiveTreeModelAdaptor>

निम्न उदाहरण दिखाता है कि ब्राउज़र में प्रोजेक्ट संरचना को कैसे प्रस्तुत किया जाए। RichFaces 3 में, इन दो टैग्स का उपयोग किया जाता है <अमीर: treeNodeAdaptor> और <अमीर: recursiveTreeNodeAdaptor>।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head>
      <title>Tree Model and Recursive Model Example</title> 
   </h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <rich:tree toggleType = "AJAX" var = "item" style = "max-width: 400px"> 
            <rich:treeModelRecursiveAdaptor roots = "#{fileSystemBean.sourceRoots}" 
               nodes = "#{item.directories}"> 
               
               <rich:treeNode> 
                  #{item.shortPath} 
               </rich:treeNode> 
               
               <rich:treeModelAdaptor nodes = "#{item.files}"> 
                  <rich:treeNode>#{item}</rich:treeNode> 
               </rich:treeModelAdaptor> 
            </rich:treeModelRecursiveAdaptor> 
            
         </rich:tree> 
      </h:form> 
   </h:body>
   
</html>

हमें इस उदाहरण के लिए दो नए जावा बीन्स बनाने की आवश्यकता है। सेम क्लास "FileSystemBean.java" के लिए कोड स्निपेट निम्नलिखित है, जो आवश्यक फ़ोल्डर नाम रखता है।

import java.util.List; 
import javax.faces.bean.ManagedBean; 
import javax.faces.bean.RequestScoped; 
  
@ManagedBean 
@RequestScoped 

public class FileSystemBean { 
   private static final String SRC_PATH = "/WEB-INF"; 
   private List<FileSystemNode> srcRoots; 
  
   public synchronized List<FileSystemNode> getSourceRoots() { 
      if (srcRoots == null) {
         srcRoots = new FileSystemNode(SRC_PATH).getDirectories(); 
      } 
      return srcRoots; 
   } 
}

सेम क्लास "FileSystemNode.java" के लिए कोड स्निपेट निम्नलिखित है, जो परियोजना की आवश्यक पत्ती नोड रखता है।

import static com.google.common.base.Predicates.containsPattern; 
import static com.google.common.base.Predicates.not; 
import static com.google.common.collect.Iterables.filter; 
import static com.google.common.collect.Iterables.transform; 
  
import java.util.ArrayList; 
import java.util.Collections; 
import java.util.List; 
import java.util.Set; 
  
import javax.faces.context.ExternalContext; 
import javax.faces.context.FacesContext; 
  
import com.google.common.base.Function; 
import com.google.common.collect.Iterables; 
import com.google.common.collect.Lists; 
  
public class FileSystemNode { 
   private static final Function<String, FileSystemNode> 
      FACTORY = new Function<String, FileSystemNode>() { 
      
      public FileSystemNode apply(String from) { 
         return new FileSystemNode(from.substring(0, from.length() - 1)); 
      }; 
   }; 
   private static final Function<String, String> 
      TO_SHORT_PATH = new Function<String, String>() {
      
      public String apply(String from) { 
         int idx = from.lastIndexOf('/'); 
         if (idx < 0) { 
            return from; 
         } 
         return from.substring(idx + 1); 
      }; 
   }; 
   private String path; 
   private List<FileSystemNode> directories; 
   private List<String> files; 
   private String shortPath; 
  
   public FileSystemNode(String path) { 
      this.path = path; 
      int idx = path.lastIndexOf('/'); 
      
      if (idx != -1) { 
         shortPath = path.substring(idx + 1); 
      } else { 
         shortPath = path; 
      } 
   } 
   public synchronized List<FileSystemNode> getDirectories() { 
      if (directories == null) { 
         directories = Lists.newArrayList(); 
  
         Iterables.addAll(directories, transform(filter(
            getResourcePaths(), containsPattern("/$")), FACTORY)); } return directories; } public synchronized List<String> getFiles() { if (files == null) { files = new ArrayList<String>(); Iterables.addAll(files, transform(filter( getResourcePaths(), not(containsPattern("/$"))), TO_SHORT_PATH)); 
      } 
      return files; 
   } 
   private Iterable<String> getResourcePaths() { 
      FacesContext facesContext = FacesContext.getCurrentInstance(); 
      ExternalContext externalContext = facesContext.getExternalContext(); 
      Set<String> resourcePaths = externalContext.getResourcePaths(this.path); 
      
      if (resourcePaths == null) { 
         resourcePaths = Collections.emptySet(); 
      } 
      return resourcePaths; 
   } 
   public String getShortPath() { 
      return shortPath; 
   } 
}

उपरोक्त उदाहरण ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।

इस अध्याय में, हम विभिन्न त्रुटियों से निपटने के तरीकों के बारे में जानेंगे जिन्हें रिचफेसेस में लागू किया जा सकता है।

सर्वर साइड और क्लाइंट साइड एरर हैंडलिंग

हमें एक्शन क्लास आधारित अपवादों को संभालने के लिए सुंदर पुरानी जावा तकनीक (कोशिश / कैच) से गुजरना होगा। क्लाइंट पक्ष के लिए, हम एक अतिरिक्त फ़ाइल जोड़ सकते हैं, जो क्लाइंट पक्ष पर कोई त्रुटि होने पर त्रुटि संदेश दिखाएगा।

कोड स्निपेट को क्लाइंट पक्ष की त्रुटियों को संभालने के लिए web.xml में जोड़ा जा सकता है।

<error-page> 
   <exception-type>java.lang.Throwable</exception-type> 
   <location>/error.xhtml</location> 
</error-page>

ध्यान दें, उपरोक्त अपवाद केवल स्थैतिक अपवाद संदेश प्रदान करेंगे और हमें गतिशील अपवाद संपत्ति का उपयोग करने के लिए JSF "ExceptionHandler" वर्ग का उपयोग करना पड़ सकता है। रनटाइम पर, रिचफेसेस इनपुट फ़ील्ड को मान्य करने के लिए कुछ सुविधाएँ प्रदान करता है, जिसका उपयोग अनुप्रयोग में अपवाद के प्राथमिक बिल्डिंग ब्लॉक के रूप में किया जा सकता है।

एक नई फ़ाइल बनाएं और उसमें निम्न कोड रखें।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Error handling</title> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
   </h:head> 
    
   <h:body> 
      <h:form id = "form"> 
         <rich:panel> 
            <f:facet name = "header"> 
               <h:panelGroup> 
                  <h:outputText value = "Student Registration" /> 
                  <a4j:status> 
                     <f:facet name = "start"> 
                        <h:graphicImage value = "/images/ai.gif" style = "height:12px;width:12px;" alt = "ai" /> 
                     </f:facet> 
                  </a4j:status> 
               </h:panelGroup> 
            </f:facet> 
            
            <h:panelGrid columns = "3"> 
               <h:outputText value = "Name:" /> 
               <h:inputText value = "#{student.name}" id = "name" label = "name"> 
                  <f:validateLength minimum = "3" maximum = "8" /> 
                  <f:validateRequired /> 
                  <rich:validator /> 
               </h:inputText> 
               <rich:message for = "name" /> 
               <h:outputText value = "Email" /> 
               
               <h:inputText value = "#{student.email}" id = "email" 
                  validatorMessage = "Ivalid email address"> 
                  
                  <f:validateRegex 
                     pattern = 
						   "^(([a-zA-Z0-9_\-\.]+)@([a-zA-Z0-9_\-\.]+)
						   \.([a-zAZ]{2,5}){1,25})+([;.](([a-zA-Z0-9_\-\.]+)
						   @([a-zA-Z0-9_\-\.]+)\.([a-zAZ]{2,5}){1,25})+)*$" /> 
                  <rich:validator /> 
               </h:inputText> 
               
               <rich:message for = "email" /> 
               <h:outputText value = "Age" /> 
               
               <h:inputText value = "#{student.age}" id = "age" label = "age"> 
                  <f:validateLongRange minimum = "18" maximum = "99" /> 
                  <rich:validator /> 
               </h:inputText> 
               <rich:message for = "age" /> 
            </h:panelGrid>
            
         </rich:panel> 
      </h:form> 
   </h:body>
   
</html>

निम्नलिखित की तरह सामान्य वर्ग का वर्ग होना चाहिए।

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.RequestScoped;  

@ManagedBean 
@RequestScoped 

public class Student { 
   private String name; 
   private String email; 
   private int age;  
   
   public String getName() { 
      return name; 
   }  
   public void setName(String name) { 
      this.name = name; 
   }  
   public String getEmail() { 
      return email; 
   }  
   public void setEmail(String email) { 
      this.email = email; 
   }
   public int getAge() { 
      return age; 
   }  
   public void setAge(int age) { 
      this.age = age; 
   } 
}

उपरोक्त उदाहरण ब्राउज़र में निम्न आउटपुट प्राप्त करेगा, जब भी <h: form> में कोई त्रुटि होगी।

संसाधन लोड हो रहा है

रिचफेस जेएसएफ एप्लिकेशन में मानक संसाधन हैंडलिंग प्रक्रिया में सुधार करता है। इसे या तो रिसोर्ससर्वलेट को कॉन्फ़िगर करके या संसाधन अनुकूलन द्वारा लागू किया जा सकता है। रिसोर्ससर्वलेट को कॉन्फ़िगर करने के लिए, हमें web.xml में निम्नलिखित कोड को जोड़ना होगा।

<servlet> 
   <servlet-name>Resource Servlet</servlet-name> 
   <servlet-class>org.richfaces.webapp.ResourceServlet</servlet-class> 
   <load-on-startup>1</load-on-startup> 
</servlet> 

<servlet-mapping> 
   <servlet-name>Resource Servlet</servlet-name> 
   <url-pattern>/org.richfaces.resources/*</url-pattern> 
</servlet-mapping>

हम JSF एप्लिकेशन में ऑप्टिमाइज़ेशन को भी सक्षम कर सकते हैं, जो विभिन्न जावास्क्रिप्ट और सीएसएस फाइलों को ऑप्टिमाइज़ करेगा। आवेदन में अनुकूलन प्राप्त करने के लिए हमें निम्नलिखित कोड जोड़ना होगा।

<context-param> 
   <param-name>org.richfaces.resourceOptimization.enabled</param-name> 
   <param-value>true</param-value> 
</context-param>