【问题标题】:Primefaces datatable sorting after filtering过滤后的 Primefaces 数据表排序
【发布时间】:2016-04-08 09:18:59
【问题描述】:

我有一个 p:dataTable 存储处理后的表单的结果,我执行以下操作:

  1. 填写表单值。
  2. 提交。
  3. 数据表已填充 -- 过滤任何列。
  4. 更改表单值。
  5. 提交。
  6. 数据表已填充新结果。
  7. 按任意列排序 -- 显示来自 #3 的过滤结果。

我有一个过滤值的数组列表,但我没有在 bean 中对它做任何事情。在提交时,我调用了一个 actionListener,它将 dataTable 转换为 primefaces.components.datatable.DataTable,然后在处理表单之前对其调用 resetValue()(参见下面的代码 sn-p)。

我尝试了多种重置、清除和更新数据表的方法,但我无法解决上述问题。仅供参考,这是我的 p:dataTable 标签:

<p:dataTable
            id="resultsDataTable"
            rendered="#{entityReportBean.isResultsPopulated}"
            var="change"
            value="#{entityReportBean.entityChangeDto}"
            styleClass="resultsPanel"
            rows="100"
            paginator="true"
            paginatorPosition="top"
            paginatorTemplate="#{PreviousPageLink}  Previous  {CurrentPageReport}  Next  {NextPageLink}"
            filterEvent="enter"
            filteredValue="#{entityReportBean.filteredResults}" >

这是actionListener:

    public void onSubmit() {
            FacesContext context = FacesContext.getCurrentInstance();
            DataTable resultsTable = (DataTable) context.getViewRoot().findComponent("results:resultsDataTable");
            resultsTable.resetValue();
                ...

我对 JSF/Primefaces 相当陌生,所以可能有一些我不知道的基本操作。有什么建议吗?

【问题讨论】:

    标签: jsf jsf-2 primefaces datatable


    【解决方案1】:

    所以我意识到尝试在我的 actionListener 中做任何事情是没有意义的,因为它没有在排序时被调用。所以我在 dataTable 上添加了一个 ajax 'sort' 事件,并向监听器添加了一个resultsTable.updateValue(entityChangeDto);。现在一切都很好。

    【讨论】:

      猜你喜欢
      • 2013-12-23
      • 2014-07-19
      • 1970-01-01
      • 2023-03-20
      • 1970-01-01
      • 2014-03-01
      • 1970-01-01
      • 1970-01-01
      • 2014-01-04
      相关资源
      最近更新 更多