我有一个带有数据表的“正常”分页。第一个“加载”从数据库中引入 25 个项目。在 ajax“页面”事件中,我将以下元素分成 25 个项目块。一切都与 Primefaces 5.1 版完美配合,但在 5.2 版中,没有调用 onPageChange 方法,实际上分页什么也不做。
如果在 ajax 事件“page”中添加 process="@this" 它确实调用了 bean,但不是指定的 onPageChange 方法,而是一个标有 @PostConstruct 注释的 start 方法(这样,前 25 个项目和分页总是相同的)显示这些项目)。
<p:panel id="..."
header="..."
style="..."
toggleable="true"
toggleSpeed="200" >
<p:dataTable var="some_var"
id="myDataTable"
widgetVar="pag"
first="#{[bean].first}" <-- bean attribute
value="#{[bean].collectionOfObjects}" <-- loading of the first 25 elements
rows="20"
paginator="true"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
emptyMessage="..."
lazy="true"
rowIndexVar="rowIndex"
rowStyleClass="#{(rowIndex mod 2) eq 0? '...' : '...'}">
<p:ajax event="page"
listener="#{[bean].onPageChange}"/> <-- load the next 25 items (successively)
<p:ajax event="sort"
listener="#{[bean].orderListing}"/>
<p:column width="..."
headerText="..."
style="..."
sortBy="#{some_var.id}"
id="...">
...
</p:column>
[rest of columns]
</p:dataTable>
</p:panel>
背面(仅作为大纲):
@PostConstruct
protected void init() {
...
this.collectionOfObjects = new GenericLazyModel<CollectionOfObjects>(...);
}
//Method not called by ajax.
public void onPageChange(PageEvent event) {
//Next 25 items
this.collectionOfObjects = new GenericLazyModel<CollectionOfObjects>(...);
}
版本:primefaces 5.2、jsf-api 2.2.2、jsf-impl 2.2.2(更新最后两个将非常昂贵)。
在这篇文章中,有几种可能性,但在仔细阅读所有内容后,我还没有设法解决错误。
未调用 commandButton/commandLink/ajax 操作/侦听器方法或未设置/更新输入值
非常感谢大家!