如何从jsf中的数据库表中填充h:selectOneMenu?

时间:2012-12-14 14:11:19

标签: java jsf selectonemenu

我有一个类别表

 categoryId
 catName
 description
 image 

我想用<h:selectOneMenu> itemLabelcategoryName填充categoryId   这是ManagedBean的价值。

应该用{{1}}来完成这个怎么办?

4 个答案:

答案 0 :(得分:1)

您可以使用SelectItem列表。你将需要一个方法来生成一个选择项列表,如你在托管bean中的下一个,

public List<SelectItem> getAllCatagories(){

   List<SelectItem> items = new ArrayList<SelectItem>();
   List<Category> categoryList = dao.getAllCategory();
    for(Category category: categotyList){
       items.add(new SelectItem(category.getCategoryId(), category.getName()));
   }
   return items;
}

并像这样使用

<h:selectOneMenu value="#{controllerBean.selectedCategory}" >
            <f:selectItems value="#{controllerBean.allCategories}"/>
</h:selectOneMenu>

答案 1 :(得分:0)

您必须使用f:selectItems标记:

<h:selectOneMenu value="#{yourBean.itemValue}">                     
    <f:selectItems value="#{yourBean.yourItems}" />
</h:selectOneMenu>

然后,YourBean需要有一个Map字段,存储从数据库中获取的值,其中地图的键(我建议是一个字符串)是标签,值是相关对象。

Map<String,YourObject> yourItems = new HashMap<String,YourObject>();

public Map<String,YourObject> getYourItems() {
    return yourItems;
}

答案 2 :(得分:0)

尝试这样的事情

XHTML

    <h:form>
        <h:panelGrid>
            <h:selectOneMenu value="#{myMB.id}">
                <f:selectItem itemLabel="Please select one" itemValue="#{null}" />
                <f:selectItems value="#{myMB.items}" />
            </h:selectOneMenu>
        </h:panelGrid>
        <h:commandButton action="#{myMB.go}" value="Go"/>
    </h:form>

MB

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;

import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import javax.faces.model.SelectItem;

@ManagedBean
@ViewScoped
public class MyMB implements Serializable{

    private static final long serialVersionUID = 1L;
    private List<SelectItem> items = new ArrayList <SelectItem> ();
    private Long id;

    @PostConstruct
    public void init(){
        SelectItem si = new SelectItem();
        si.setLabel("My Label");
        si.setValue(666L);

        items.add(si);
    }

    public List<SelectItem> getItems() {
        return items;
    }

    public void setItems(List<SelectItem> items) {
        this.items = items;
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public void go(){
        System.out.println(id);
    }
}

答案 3 :(得分:0)

您可以使用循环从列表中获取数据,如下所示:

<h:outputText value="Role :" />
<p:selectOneMenu value="#{myBean.id_Role}">
    <c:forEach var="role" items="#{myBean.rolesList}">
        <f:selectItem itemLabel="${role.name_Role}" itemValue="${role.id_Role}" />
    </c:forEach>
</p:selectOneMenu>

在你的bean中:

private List<Role> rolesList;
//And then fill the list from database 

在我的情况下,我使用hibernate从数据库中获取数据,它对我有用。

我希望它有用!