在primefaces组件中延迟加载

时间:2014-12-15 11:48:08

标签: java jsf primefaces

我的实体延迟加载到dataScroller时遇到问题。

以下是my.xhtml

的批量
<h:form>
  <p:dataScroller value="#{userBean.lazyModel}" var="user" chunkSize="10" lazy="true"> 
  <f:facet name="loader">
    <p:commandButton type="button" value="More" icon="ui-icon-circle-triangle-s"/>
  </f:facet>

  <h:panelGrid columns="2" style="width:100%" columnClasses="logo,detail">
    <p:outputPanel>
    <h:panelGrid columns="2" cellpadding="5">
    <h:outputText value="Id:"/>
    <h:outputText value="#{user.id}" style="font-weight: bold"/>

    <h:outputText value="name:"/>
    <h:outputText value="#{user.name}" style="font-weight: bold"/>

  </h:panelGrid>
</p:outputPanel>
</h:panelGrid>
</p:dataScroller>

这是LazyDataModel规范

 private LazyDataModel<User> lazyModel; 
   @PostConstruct
    public void init() {
        this.lazyModel = new LazyDataModel<User>() {
            private static final long serialVersionUID = 1L;

            @Override
            public List<User> load(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String, Object> filters) {
                List<User> data = userService.getUsersFromTo(0 , first + pageSize);  
                this.setRowCount(data.size());
                return data;
            }
        };
    }

    public LazyDataModel<User> getLazyModel() {
        return lazyModel;
    }

一切都应该像facebook中的无限滚动一样工作。但有一个问题。我得到10个用户,在下载后,我得到另外10个用户,但它们与之前相同(相同的ID名称等...) 我试着调试它。一切似乎都很好。加载函数中返回的数据包含正确的数据......任何人都面临同样的问题,或者我在哪里错了?

1 个答案:

答案 0 :(得分:0)

不应该这个

userService.getUsersFromTo(0 , first + pageSize); 

而不是

userService.getUsersFromTo(first , first + pageSize); 

在第一种情况下,前十个用户将始终相同,但每个步骤返回的用户数量将增加,这可能是导致问题的原因