JSF 2.0 + PrimeFaces: dataTable页面计数不起作用



我在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}

添加这个也可以。

相关内容

  • 没有找到相关文章

最新更新