我在omnifaces 的展示中搜索了任何有助于JSF(数据表)真实分页的组件,但没有成功。
大家知道有没有吗?
这将是一个很棒的功能。
我在这里采取了一些方法https://rogerkeays.com/blog/paging-large-data-sets-with-a-lazylist并附带以下代码。
它非常通用,可以与任何 JSF 组件库或持久性 API 一起使用。
开发人员必须在他的 JSF 托管 bean(支持 bean)中实现惰性列表,它可以访问业务外观或实体管理器来执行查询。
import java.util.AbstractList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public abstract class AbstractLazyList extends AbstractList {
/**
* Current page cache.
*/
private final Map<Integer, Object> currentPage = new HashMap<Integer, Object>();
/**
* Page size. Default 50.
*/
private int pageSize = 50;
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
@Override
public Object get(int index) {
if (currentPage.containsKey(index)) {
return currentPage.get(index);
}
queryNewPage(index);
return currentPage.get(index);
}
/**
* Clears cache and queries new page's itens.
*
* @param firstItemIndex
* first item index
*/
private void queryNewPage(int firstItemIndex) {
currentPage.clear();
final List<Object> pageResults = queryNextPage(firstItemIndex, pageSize);
for (int j = 0; j < pageResults.size(); j++) {
currentPage.put(firstItemIndex + j, pageResults.get(j));
}
}
@Override
public int size() {
return queryResultsSize();
}
/**
* Queries next page itens.
*
* @param firstRowIndex
* first row index
* @param pageSize
* maximum resuts of the query
* @return list of results
*/
protected abstract List<Object> queryNextPage(int firstRowIndex,
int pageSize);
/**
* Counts the total results of the query.
*
* @return query's total results
*/
protected abstract int queryResultsSize();
}
}
也许这样的方法可以适用于全方位。