我在Tomcat 6.0和PrimeFaces 2.2.1上使用Mojarra 2.0.3。
我使用带有延迟加载的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;
};
}
我希望它不是主要版本中的错误,因为我不能等到新版本出来(项目必须在3周内准备好)。
有没有人有想法?我尝试了一切,但没有任何工作。
来自德国的问候,安迪
答案 0 :(得分:1)
好吧,我想你的算术异常除以0,尝试在实例化懒惰的datamodel对象后添加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
}
答案 1 :(得分:1)
您使用以下属性进行分页
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
你为paginatorTemplate保留了所有东西但是你忘了再添加一个
{PageLinks}
添加这个也可以。