gpt4 book ai didi

java - 如何在 JSF 中正确呈现数据库中存储的类别列表

转载 作者:行者123 更新时间:2023-12-02 08:05:42 25 4
gpt4 key购买 nike

我正在申请并登记问题。每个问题都与一个或多个类别相关,因此我需要在注册问题表单中选择一种方法来选择它所属的类别。

我正在考虑使用 JSF 中的 selectMany... 组件之一来完成该任务。我可以检索数据库中所有类别的列表(仅 9 个),然后将该列表绑定(bind)到 f:selectItems 组件。那么每个selectItem的itemValue必须是category的id。我还需要第二个列表,其中包含类别的所有选定 id,最后使用每个 id 再次对数据库进行某种查询,并将其添加到列表中......这再次根据问题进行设置。

我不需要解释如何检索列表等,但如果这种方法有什么好处,我可能需要一些帮助?替代方案已被广泛接受:=)

最佳答案

制造List<Category> Question 的属性实体。

@Entity
public class Question {

@OneToMany
private List<Category> categories;

// ...
}

<h:selectManyMenu value="#{question.categories}" converter="#{categoryConverter}">
<f:selectItems value="#{data.categories}" />
</h:selectManyMenu>

您只需提供 Category 的转换器类。

@ManagedBean
@RequestScoped
public class CategoryConverter implements Converter {

@EJB
private CategoryService categoryService;

@Override
public String getAsString(FacesContext context, UIComponent component, Object value) {
if (!(value instanceof Category) || ((Category) value).getId() == null) {
return null;
}

return String.valueOf(((Category) value).getId());
}

@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
if (value == null || !value.matches("\\d+")) {
return null;
}

return categoryService.find(Long.valueOf(value));
}

}

(注意:在 JSF 2.2 之前,不可能在 @EJB 中注入(inject) @FacesConverter ,这就是为什么它是 @ManagedBean ,另请参阅 Communication in JSF 2.0 - Converting and validating GET request parameters )

您不需要在托管 bean 或其他内容中复制所选项目。

关于java - 如何在 JSF 中正确呈现数据库中存储的类别列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8202569/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com