我的实体延迟加载到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名称等...) 我试着调试它。一切似乎都很好。加载函数中返回的数据包含正确的数据......任何人都面临同样的问题,或者我在哪里错了?
答案 0 :(得分:0)
不应该这个
userService.getUsersFromTo(0 , first + pageSize);
而不是
userService.getUsersFromTo(first , first + pageSize);
在第一种情况下,前十个用户将始终相同,但每个步骤返回的用户数量将增加,这可能是导致问题的原因