RichFaces-반복 구성 요소

이전 장에서 다양한 입력 및 출력 구성 요소에 대해 배웠습니다. 이 장에서는 웹 사이트의 다양한 데이터 구조를 반복하는 방법을 배웁니다.

<rich : 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>

목록을 렌더링하려면 subject.java를 적절히 변경해야합니다. 다음은 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; 
   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; 
   } 
}

위의 예는 브라우저에서 다음 출력을 생성합니다.

<rich : dataDefinitionList>

모델에서 데이터 정의를 생성하는 데 사용되는 태그입니다. 이 태그는 RichFaces 4가 발명 된 이후 JBoss에서 지원되지 않습니다. 여전히 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"은 자동차의 다른 값을 생성하는 데 사용되는 Java 클래스입니다. 이것은 <datatable> 태그를 사용하여 많은 객체 값을 채운 이전 태그와 유사합니다.

<rich : dataOrderedList>

RichFaces 4는 RichFaces 3에서 광범위하게 조정되었습니다. <dataOrderedList>는 목록을 순서대로 렌더링하는 데 사용되는 태그입니다. 이 역시 RichFaces 4에서는 억제됩니다. Java로 수행 할 경우 객체 또는 목록의 순서가 훨씬 더 쉽고 시간도 적게 걸리기 때문입니다. 응용 프로그램에서 RichFaces 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"은 "airlinesBean ()"이라는 메소드가있는 Java Bean 클래스입니다. 이 메서드는 "air"유형의 개체를 반환합니다. 나중에이 공기 객체를 사용하여 테이블 형식으로 다른 속성을 채울 수 있습니다.

<rich : dataList>

태그 이름에서 알 수 있듯이이 태그는 순서가 지정되지 않은 목록을 브라우저에 렌더링하는 데 사용됩니다. 그러나 <orderList>와 마찬가지로이 태그는 최신 버전의 RichFaces에서도 표시되지 않습니다. 다음과 같은 방법으로 <a4j : Repeat> 및 <rich : dataTable> 태그를 사용하여 목록을 브라우저에 쉽게 렌더링 할 수 있습니다.

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

위의 예에서는“subjectList ()”라는 메서드의 출력 인 목록을 렌더링합니다. 응용 프로그램이 RichFaces 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>

<rich : dataGrid>

<datatable> 태그를 사용하면 목록을 테이블로 렌더링 할 수 있지만 <dataGrid>는 개체 또는 목록을 렌더링하는 데 도움이됩니다. <rich : datatable>의 이전 예제에서 xhtml 페이지를 다음과 같이 변경하고 동일한 결과가 무엇인지 확인하십시오.

<?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>

위의 코드는 브라우저에서 다음과 같은 출력을 생성합니다.

<rich : datascroller>

이 태그는 테이블 데이터를 채우는 동안 스크롤 막대를 만드는 데 도움이됩니다. JSF의 페이지 매김 기능과 매우 유사합니다. 다음과 같이 이전 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" 
            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> 태그를 구현했습니다. 다음은 위 파일의 출력입니다. 테이블과 데이터 스크롤러를 동기화하기 위해 스타일 sheer 속성을 업데이트하십시오.