java web分页无外乎两种,一种是直接取出来,放到一个集合里,通过传begin 和 end 参数控制分页,还有一种就是把分页工作交给数据库,让数据库读取需要的begin~end之间的数据。
JAVA分页实现代码示例:
package com.page;
public class PageUtil {
// 每页显示的条数
private int pageSize;
// 总共的条数
private int recordCount;
// 当前页面
private int currentPage;
public PageUtil(int pageSize, int recordCount, int currentPage) {
this.pageSize = pageSize;
this.recordCount = recordCount;
setCurrentPage(currentPage);
}
// 构造方法
public PageUtil(int pageSize, int recordCount) {
this(pageSize, recordCount, 1);
}
// 总页数
public int getPageCount() {
// 总条数/每页显示的条数=总页数
int size = recordCount / pageSize;
// 最后一页的条数
int mod = recordCount % pageSize;
if (mod != 0)
size++;
return recordCount == 0 ? 1 : size;
}
// 包含,起始索引为0
public int getFromIndex() {
// System.out.println("from index:"+(currentPage-1) * pageSize);
return (currentPage - 1) * pageSize;
}
// 不包含
public int getToIndex() {
// System.out.println("to index:"+Math.min(recordCount, currentPage *
// pageSize));
return Math.min(recordCount, currentPage * pageSize);
}
// 得到当前页
public int getCurrentPage() {
return currentPage;
}
// 设置当前页
public void setCurrentPage(int currentPage) {
int validPage = currentPage <= 0 ? 1 : currentPage;
validPage = validPage > getPageCount() ? getPageCount() : validPage;
this.currentPage = validPage;
}
// 得到每页显示的条数
public int getPageSize() {
return pageSize;
}
// 设置每页显示的条数
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
// 得到总共的条数
public int getRecordCount() {
return recordCount;
}
// 设置总共的条数
public void setRecordCount(int recordCount) {
this.recordCount = recordCount;
}
}
-------------------------------------------------------------------------------------------
下面的代码是放在jsp里面的
-------------------------------------------------------------------------------------------
<%
PublishersDAO dao = PublishersDAO.getInstance();
List records = dao.getModels();
String pageStr = request.getParameter("page");
int currentPage = 1;
if (pageStr != null)
currentPage = Integer.parseInt(pageStr);
PageUtil pUtil = new PageUtil(10, records.size(), currentPage);
currentPage = pUtil.getCurrentPage();
%>
-----------下面这个是放在有变量的上面--------------------------------------------------
<%
for (int i = pUtil.getFromIndex(); i < pUtil.getToIndex(); i++) {
PublisherModel model = (PublisherModel) records.get(i);
%>
//中间是删除修改之类的代码
<%}%>
------------这个是结尾的-----------------------------------------------------------------
这个方法非要一次全部返回吗。
Soap.GetWebServre("selectAllCargoInfor", arrayList, brrayList);
如果这个方法不分页,那在本地分页,是没多大意义的。
for (int j = 0; j < crrayList.size(); j += 6) {
这里可以分页,但已经是客户端了
楼上回答正确,如果非要分页
/**
原始数据,一页行数,页码
*/
public List getPage(List list,int onePageLine,int pageNum){
if(list!=null&&list.size()>=onePageLine*pageNum){
return list.subList(onePageLine*(pageNum-1),onePageLine*pageNum);
}
return null;
}
请关注www.highersoft.net
(1) .数据放在List中是可以实现分页的,基本原理是因为List集合是有序的。
需要定义一下几个参数:
int pagerSize; 每一页展示的条数
int currentPageIndex; 当前页的序号
int startRowIndex; 查询记录的起始下标
int totalPage; list中的记录能被分成的总页数
(2). totalPage = list.size() % pagerSize == 0 ? list.size()/pagerSize : (list.size() / pagerSize + 1);
startRowIndex = (currentPageIndex - 1) * pagerSize;
(3).重新定义一个List集合存放分页出来的数据
LIst
for (int i = startRowIndex; i < startRowIndex + pagerSize; i++)
{
divideMap.add(list.get(i));
}