|
選擇類標籤可以搭配<f:selectItem>或<f:selectItems>標籤來設定選項,例如: <f:selectItem itemLabel="高中"
itemValue="高中" itemDescription="學歷" itemDisabled="true"/> itemLabel屬性設定顯示在網頁上的文字,itemValue設定發送至伺服端時的值,itemDescription 設定文字描述,它只作用於一些工具程式,對HTML沒有什麼影響,itemDisabled設定是否選項是否作用,這些屬性也都可以使用JSF Expression Language來綁定至一個值。 <f:selectItem>也可以使用value來綁定一個傳回javax.faces.model.SelectItem的方法,例如: <f:selectItem value="#{user.sex}"/>
則綁定的Bean上必須提供下面這個方法: ....
public SelectItem getSex() { return new SelectItem("男"); } .... 如果要一次提供多個選項,則可以使用<f:selectItems>,它的value綁定至一個提供傳回SelectItem?的陣列、集合,或者是Map物件的方法,例如: <h:selectOneRadio value="#{user.education}">
<f:selectItems value="#{user.educationItems}"/> </h:selectOneRadio><p> 這個例子中<f:selectItems>的value綁定至user.educationItems,其內容如下: ....
private SelectItem[] educationItems; public SelectItem[] getEducationItems() { if(educationItems == null) { educationItems = new SelectItem[3]; educationItems[0] = new SelectItem("高中", "高中"); educationItems[1] = new SelectItem("大學", "大學"); educationItems[2] = new SelectItem("研究所以上", "研究所以上"); } return educationItems; } .... 在這個例子中,SelectItem的第一個建構參數用以設定value,而第二個參數用以設定label,SelectItem還提供有數個建構函式,記得可以參考一下線上API文件。 您也可以提供一個傳回Map物件的方法,Map的key-value會分別作為選項的label-value,例如: <h:selectManyCheckbox layout="pageDirection"
value="#{user.preferColors}"> <f:selectItems value="#{user.preferColorItems}"/> </h:selectManyCheckbox><p> 您要提供下面的程式來搭配上面這個例子: ....
private Map preferColorItems; public Map getPreferColorItems() { if(preferColorItems == null) { preferColorItems = new HashMap(); preferColorItems.put("紅", "Red"); preferColorItems.put("黃", "Yellow"); preferColorItems.put("藍", "Blue"); } return preferColorItems; } .... |