我在Tomcat 6.0和PrimeFaces 2.2.1上使用Mojarra 2.0.3。
我使用了一个带有lazyloading的dataTable,它可以正常工作。现在我添加了分页,表格计算页数不正确。
<p:dataTable id="tableList" value="#{overview.lazyModel}" rendered="#{!overview.listEmpty}" var="e"
paginator="true" rows="10" lazy="true"
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
rowsPerPageTemplate="5, 10, 20, 50">
在第一次加载时,有时它不显示数据,尽管bean正确地发送了数据(我打印了数据,发送到表中,进入tomcat控制台)并且表中的数据(pagesize, filters, sortMode,…)是正确的。
lazyModel = new LazyDataModel<Bericht>() {
@Override
public List<Bericht> load(int first, int pageSize, String sortField, boolean sortOrder, Map<String,String> filters) {
List<Bericht> lazyBerichte;
lazyBerichte = [...]; // fill data
setRowCount([...]); // set row count
return lazyBerichte;
};
}
我希望这不是primefaces的bug,因为我等不及新版本出来了(项目必须在3周内准备好)。
有人有什么想法吗?我什么都试过了,但都不行。
来自德国的问候,Andy
好吧,我想你得到一个算术异常除以0,尝试添加rowCount和pageSize实例化后你的懒惰数据模型对象。就像
lazyModel = new LazyDataModel<Bericht>() {
@Override
public List<Bericht> load(int first, int pageSize, String sortField, boolean sortOrder, Map<String,String> filters) {
List<Bericht> lazyBerichte;
lazyBerichte = [...]; // fill data
setRowCount([...]); // set row count
return lazyBerichte;
};
lazyModel.setRowCount(totalRowsNumberWithoutFilters); //you should put here the total rows of your table, something like a select * from x or findAll() jpa method
lazyModel.setPageSize(10); //put the rows per page number
}
您使用下面的属性进行分页
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
您保留了paginatorTemplate的所有内容,但是您忘记添加一个
{PageLinks}
添加这个也可以。