1

我在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();
}
}

也许这样的方法可以适用于全方位。

4

1 回答 1

2

OmniFaces 不适合面向视觉的 UI 组件,而更适合于“在幕后”工作并且可以与任何其他 JSF 组件库结合使用的实用程序。

考虑查看面向视觉的 UI 组件库,例如 PrimeFaces 和 RichFaces。它们提供具有分页可能性的数据表组件。

于 2012-07-26T17:17:57.653 回答