如何遍历List <t>并渲染JSF Facelets中的每个项目</t>

时间:2013-11-20 14:29:56

标签: list jsf facelets data-presentation

我想知道如何在Facelet中显示下面获得的List<T>

public List<T> searchByString(String string) {
    return getEntityManager().createNamedQuery("Userdetails.findByUsername").setParameter("username", "%" + string + "%").getResultList();
}

<h:dataTable>是否合适?

2 个答案:

答案 0 :(得分:11)

你需要迭代它。 JSF 2提供了三个迭代组件。如果User实体如下所示,

@Entity
public class User {
    private @Id Long id;
    private String username;
    private String email;
    private LocalDate birthdate;
    // Add/generate getters+setters.
}

并且搜索结果被指定为bean的List<User> users属性,可用作#{bean}

@Named @RequestScoped
public class Bean {
    private List<User> users;
    // Add/generate postconstruct+getter.
}

这里有一些基于它的例子:

  1. <h:dataTable>,一个生成HTML <table>

    的UI组件
    <h:dataTable value="#{bean.users}" var="user">
        <h:column>#{user.id}</h:column>
        <h:column>#{user.username}</h:column>
        <h:column><a href="mailto:#{user.email}">#{user.email}</a></h:column>
        <h:column>#{user.birthdate}</h:column>
    </h:dataTable>
    
  2. <ui:repeat>,一个不生成HTML标记的UI组件(因此,您必须自己以所需的方式编写所有HTML,这可以很容易地更改为例如<ul><li> ,或<dl><dt><dd>,或<div><span>等):

    <table>
        <ui:repeat value="#{bean.users}" var="user">
            <tr>
                <td>#{user.id}</td>
                <td>#{user.username}</td>
                <td><a href="mailto:#{user.email}">#{user.email}</a></td>
                <td>#{user.birthdate}</td>
            </td>
        </ui:repeat>
    </table>
    
  3. <c:forEach>,一个标签处理程序,在视图构建时运行而不是查看渲染时间(这里的背景说明:JSTL in JSF2 Facelets... makes sense?),它也不会产生任何HTML标记:

    <table>
        <c:forEach items="#{bean.users}" var="user">
            <tr>
                <td>#{user.id}</td>
                <td>#{user.username}</td>
                <td><a href="mailto:#{user.email}">#{user.email}</a></td>
                <td>#{user.birthdate}</td>
            </td>
        </c:forEach>
    </table>
    
  4. 另见:

答案 1 :(得分:1)

您可以将List保存在类变量中,为其提供一个getter和(可能)setter。将searchByString方法声明为void并将其称为a(假设您使用的是PrimeFaces):

<p:commandLink update="@form" process="@this" action="#{myBean.searchByString}"> 

为myBean:

public void searchByString(String string) {     
    userList = getEntityManager().createNamedQuery("Userdetails.findByUsername").setParameter("username", "%" + string + "%").getResultList();
}

如果您的表格位于您刚刚更新的表单中,则可以在其中显示List

 <p:dataTable var="user" value="#{myBean.userList}">  
    <p:column headerText="Name">  
        <h:outputText value="#{user.name}" />  
    </p:column>  
 </p:dataTable>