रिचफेसेस - Iteration Component

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

<अमीर: 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> टैग लागू किए हैं। निम्नलिखित उपरोक्त फ़ाइल का आउटपुट होगा। तालिका और डेटा स्क्रोलर को सिंक्रनाइज़ करने के लिए शैली सरासर विशेषता को अपडेट करें।