sorting - JSF2/Primefaces dataTable 排序不适用于 ViewScoped bean

原文 标签 sorting jsf-2 datatable primefaces

我想将排序添加到 PrimeFaces 3.3 dataTable 并创建了以下 ViewScoped bean 来存储列表,因此它不会一直从 EJB 中获取:

@Named
@ViewScoped
public class CustomerList implements Serializable {

    private static final long serialVersionUID = 6168621124401208753L;

    @EJB 
    CustomerEJB customerBean;

    List<Customer> allCustomers = null;

    public void loadCustomerList() {
        allCustomers = customerBean.findAll();
    }

    public List<Customer> getList() {
        if (allCustomers == null) {
            loadCustomerList();
        }
        return allCustomers;
    }

}

这是使用 bean 的 View :
<ui:composition template="/WEB-INF/templates/template.xhtml">

  <ui:define name="content">

        <h:form id="customerList">

          <p:dataTable id="customer" var="customer"
            value="#{customerList.list}" sortBy="#{customer.id}"
            paginator="true" rows="10" paginatorAlwaysVisible="false"
            paginatorPosition="top">
            <p:column sortBy="#{customer.id}">
              <f:facet name="header">
                <h:outputText value="#{msg.customerIdLabel}" />
              </f:facet>
              <h:outputText value="#{customer.id}" />
            </p:column>
            <p:column sortBy="#{customer.lastName}">
              <f:facet name="header">
                <h:outputText value="#{msg.customerLastNameLabel}" />
              </f:facet>
              <h:outputText value="#{customer.lastName}" />
            </p:column>

问题是我可以单击列标题进行排序,但表格仍然未排序,即使初始排序也不起作用。当您在 getList() 方法中设置断点时,我可以看到在处理请求期间从 EJB 中多次获取列表。
只要 ViewScope 处于事件状态,不应该存储 bean 吗?

最佳答案

首先,与您的问题没有直接关系,但是:
您永远不应该将您的业务方法放入组件 getter 中(即使使用 null 检查,我认为这是一种不好的做法)。请改用 @PostConstruct 注释:

@PostConstruct
public void loadCustomerList() {
    allCustomers = customerBean.findAll();
}

public List<Customer> getList() {
    return allCustomers;
}

每次构造 ViewScoped bean 时都会调用 loadCustomerList。
另外,检查您的导入以获取范围注释:
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;

最后你的课应该是这样的:
@ViewScoped
@ManagedBean
public class CustomerList implements Serializable {
    ...
}

关于sorting - JSF2/Primefaces dataTable 排序不适用于 ViewScoped bean,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12229561/

相关文章:

java - 如何同时使用导航规则和 f :ajax

google-app-engine - API 调用 datastore_v3.Put() 的请求太大。使用 Objectify (DataStore) 而不是上传文件

c# - 我应该使用什么控件来显示动态数据(图片、名称等),例如 asp.net 上的 html 表?

php - Elasticsearch仅按字母排序而不按数字排序

android - 如何使用MVVM Android应用程序中的存储库模式和实时数据正确地对列表进行排序?

internet-explorer - p :media with PDF file causes "File does not begin with ' %PDF -'." error in IE7

php - 带有Laravel和mysql的错误数据表:DataTables警告:表ID =示例-Ajax错误

c# - 如何删除数据表中的所有行

c - 通过数组实现遇到 Downheap 算法问题

sorting - 如何在保留原始位置记录的同时对表格进行排序?