JSF 组合框:显示集合中的项目

发布于 2024-12-01 19:38:24 字数 341 浏览 4 评论 0原文

我无法使用 Java 集合中的预定义数据填充 JSF 组合框。

后端,用于收集的简单存根:

PriceRecord pr = new PriceRecord();
pr.setTypeCode(Arrays.asList(123L,456L));

这不起作用,组合框保持为空:

<h:selectOneMenu value="#{price.typeCode}" var="code">
    <f:selectItem value="#{code}"/>
</h:selectOneMenu>

I can't populate a JSF combo box with predefined data from a Java collection.

Backend, simple stub for collection:

PriceRecord pr = new PriceRecord();
pr.setTypeCode(Arrays.asList(123L,456L));

This doesn't work, the combo box remains empty:

<h:selectOneMenu value="#{price.typeCode}" var="code">
    <f:selectItem value="#{code}"/>
</h:selectOneMenu>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

dawn曙光 2024-12-08 19:38:24

您给出的代码似乎没有多大意义。习惯用法更像是这样的:

<h:selectOneMenu value="#{backingBean.typeCode}">               
    <f:selectItems value="#{backingBean.typeCodes}" var="typeCode" itemLabel="#{typeCode}" itemValue="#{typeCode}" />
</h:selectOneMenu>

这里,#{backingBean.typeCode} 是最初返回表示默认选定值的单个值的属性。如果为空,则最初不会选择任何值。用户提交表单后,它将收到用户选择的值。对于您的代码,这将是 Long 类型。

#{backingBean.typeCodes} 是返回用户可以选择的所有值的集合的属性。对于您的代码,这将是 List

因为您的值是简单的长整型,所以这里的标签和值是相同的。如果它是一个更复杂的对象,例如用户,您可以使用类似 #{user.name} 的 itemLabel 和 #{user.id} 作为 itemValue 。为 itemValue 呈现的内容都会被推送到 selectOneMenu 组件的值绑定中。

另一个提示:一般来说,您应该尽量避免在支持 bean 中使用 SelectItem 类型。更喜欢简单的域对象及其集合,而不是 JSF 特定类型。

The code you've given doesn't seem to make a lot of sense. The idiom is more like this:

<h:selectOneMenu value="#{backingBean.typeCode}">               
    <f:selectItems value="#{backingBean.typeCodes}" var="typeCode" itemLabel="#{typeCode}" itemValue="#{typeCode}" />
</h:selectOneMenu>

Here, #{backingBean.typeCode} is the property that initially returns the single value that represents the default selected value. If it's empty, no value is initially selected. After the user submits the form, it will receive the value the user selected. For your code this would be of type Long.

#{backingBean.typeCodes} is the property that returns a collection of all the values a user can choose between. For your code this would be List<Long>.

Because your values are simple longs, the label and value is the same here. If it was a more complex object like e.g. a User, you could use something like #{user.name} for the itemLabel and #{user.id} for the itemValue. Whatever is rendered for itemValue is what is pushed into the value binding of the selectOneMenu component.

One other hint: in general you should try to avoid using the type SelectItem in your backing beans. Prefer simple domain objects and collections of them instead of JSF specific types.

青瓷清茶倾城歌 2024-12-08 19:38:24

我不确定问题到底是什么,但我可以给您一个非常简单的示例,说明如何使用 组件。

price.xhtml:

<h:selectOneMenu id="priceMenu" value="#{priceBean.selectedPrice}">
    <f:selectItems value="#{priceBean.prices}" />
</h:selectOneMenu>

PriceBean.java:

..
private String selectedPrice;
..
public String getSelectedPrice() {
    return selectedPrice;
}

public void setSelectedPrice(String newPrice) {
    selectedPrice = newPrice;
}
..
public List<SelectItem> getPrices() {
    List<SelectItem> retVal = new ArrayList<SelectItem>();

    retVal.add(new SelectItem("2"));
    retVal.add(new SelectItem("4"));
    retVal.add(new SelectItem("6"));

    return retVal;
}

有关SelectItem。如果你想直接使用一个特殊的对象,例如一个名为 Price 的对象,你必须使用转换器。 这里显示了一个示例。

I'm not sure what exactly the question is, but I can give you a very simple example how you could use the <h:selectOneMenu /> component.

price.xhtml:

<h:selectOneMenu id="priceMenu" value="#{priceBean.selectedPrice}">
    <f:selectItems value="#{priceBean.prices}" />
</h:selectOneMenu>

PriceBean.java:

..
private String selectedPrice;
..
public String getSelectedPrice() {
    return selectedPrice;
}

public void setSelectedPrice(String newPrice) {
    selectedPrice = newPrice;
}
..
public List<SelectItem> getPrices() {
    List<SelectItem> retVal = new ArrayList<SelectItem>();

    retVal.add(new SelectItem("2"));
    retVal.add(new SelectItem("4"));
    retVal.add(new SelectItem("6"));

    return retVal;
}

Further informations about the SelectItem. If you want to use a specially object directly, for example an object called Price, you have to use a converter. Here an example is shown.

守不住的情 2024-12-08 19:38:24

假设使用 JSF 2.0,请尝试使用 官方文档中的示例:


  

在前面的示例中,第 1 行的 value 属性指向 Collection。 HobbitBean 只是一个常规 Java 对象 (POJO),其属性符合 JavaBeans 命名约定。第 2 行的 value 属性指向 List,尽管它也可以指向 Collection、数组或 javax.faces.model .DataModel。第 3 行到第 9 行(含)的属性利用了该值是 POJO 集合这一事实。

Assuming JSF 2.0, try <f:selectItems> instead. Example from the official docs:

<h:selectOneListbox size="1" id="escape02" value="#{select05NoSelection.initialCollectionValues}">
  <f:selectItems value="#{select05NoSelection.hobbitList}"
                 var="n"
                 itemValue="#{n}"
                 itemLabel="#{n.bio}"
                 itemDescription="#{n.description}"
                 itemDisabled="#{n.disabled}"
                 itemLabelEscaped="true"
                 noSelectionValue="#{select05NoSelection.hobbitList[0]}"/>
</h:selectOneListbox>

In the preceding example, the value attribute on line 1 points to a Collection<HobbitBean>. HobbitBean is just a regular Java Object (POJO) that conforms to JavaBeans naming conventions for its properties. The value attribute on line 2 points to a List<HobbitBean>, though it could just as well point to a Collection, array, or javax.faces.model.DataModel. The attributes on lines 3 through 9, inclusive, leverage the fact that the value is a collection of POJOs.

单身狗的梦 2024-12-08 19:38:24

为了使您的页面正常工作,您可以使用 c:forEach 来迭代项目:

<h:selectOneMenu>
    <c:forEach items="#{price.typeCode}" var="code">
        <f:selectItem itemValue="#{code}" itemLabel="#{code}"/>
    </c:forEach>
</h:selectOneMenu>

To make your page just work you can use c:forEach to iterate items:

<h:selectOneMenu>
    <c:forEach items="#{price.typeCode}" var="code">
        <f:selectItem itemValue="#{code}" itemLabel="#{code}"/>
    </c:forEach>
</h:selectOneMenu>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文