RichFaces - Komponen Seleksi

Dalam bab ini, kita akan belajar tentang berbagai komponen pilihan yang disediakan oleh Teknologi RichFaces.

<rich: pickList>

Dengan menggunakan tag ini, kita dapat memilih satu nilai dari daftar yang dihuni. Ini juga memungkinkan kita untuk menambah dan menghapus komponen daftar ke Daftar lain. Contoh berikut menunjukkan cara kerjanya. Silakan buat satu file xhtml dan beri nama sebagai "pickListExample.xhtml" dan tempatkan kode berikut di dalamnya.

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

Kita perlu memodifikasi file managedBean.java untuk mengisi komponen daftar di file xhtml. Berikut adalah snapshot dari file Java kami yang telah dimodifikasi.

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; 
   } 
}

Potongan kode di atas akan menghasilkan keluaran berikut di browser. Atribut "nilai" dari tag pickList tidak lain adalah "getSubjectList ()" dari kelas kacang. "ItemValue" adalah singkatan dari kelas objek dan "itemLabel" yang sesuai adalah nama nilai instance. Dalam contoh ini, tag pickList kami secara otomatis membuat dua daftar terpisah bernama "sourceCaption" dan "targetCaption". Atribut orderable digunakan untuk mempertahankan urutan pemilihan dalam Daftar target.

<rich: orderingList>

Tag ini digunakan untuk membuat daftar secara keseluruhan. <orderingList> akan secara otomatis menyediakan beberapa fungsi seperti tombol untuk menyebar melalui daftar dan membantu memesan item yang dipilih. Pada contoh berikut, kita akan membuat satu orderingList menggunakan kode berikut untuk "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>

Kita tidak perlu mengubah kelas kacang kita karena kita mengisi daftar yang sama lagi menggunakan tag yang berbeda untuk representasi yang berbeda. Seperti contoh sebelumnya, bahkan di sini atribut nilai menampung seluruh daftar yang berasal dari "getSubjectList ()". "ItemValue" dan "itemLabel" masing-masing memiliki nilai kelas objek dan variabel instance terkait.

Potongan kode di atas akan menghasilkan keluaran berikut di browser.

<rich: ListShuttle>

Tag ListShuttle tersedia di RichFaces 3. Ini membantu menyebarkan melalui satu daftar dan menempatkan nilai yang sama ke dalam daftar lainnya. Di RichFaces 4, tag ini telah disembunyikan karena fungsionalitas yang sama dapat dicapai oleh tag baru lain bernama <rich: pickList> seperti dijelaskan di atas. Jika Anda menggunakan RichFaces 3.0, maka Anda dapat menggunakan tag ini dengan cara berikut.

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

Sangat mudah menggunakan pickList daripada menggunakan tag ini, karena fungsionalitas yang sama dapat dicapai dengan menggunakan pickList dengan hanya menulis dua baris kode.