java项目中常用的分页对象Page

在使用JAVA平台开发企业级应用时,常常会遇到分页的场景,而且每一个项目都有自己的分页方法。现在给出我自己总结的比较通用的分页对象,以供有需之人参考。

package cn.cgs.corejava.model.persistent;

import java.io.Serializable;
import java.util.List;

/**
 * 与前端交互的分页数据对象
 * 
 * @author 陈淦森
 * @param <E>
 * @version 1.0.1
 * @Date 2016年1月4日
 */
public class Page<E> implements Serializable {

	/**
	 * 
	 */
	private static final long serialVersionUID = -4973539948210269342L;
	/**
	 * 默认页码
	 */
	public static final int DEFAULT_PAGE_NO = 1;
	/**
	 * 默认页面大小
	 */
	public static final int DEFAULT_PAGE_SIZE = 10;
	/**
	 * 默认的快速导航页码显示个数
	 */
	public static final int DEFAULT_PAGE_NAV_SIZE = 5;

	private int pageNo = DEFAULT_PAGE_NO; // 页码
	private int pageSize = DEFAULT_PAGE_SIZE; // 页面大小
	private int pageNaviSize = DEFAULT_PAGE_NAV_SIZE; // 页码快速导航显示的个数
	private int totalCount; // 总的记录数
	private List<E> resultList; // 返回的查询结果集

	public Page() {
		super();
	}

	public Page(int pageNo, int pageSize) {
		super();
		setPageNo(pageNo);
		setPageSize(pageSize);
	}

	public Page(int pageNo, int pageSize, int pageNaviSize) {
		this(pageNo, pageSize);
		setPageNaviSize(pageNaviSize);
	}

	public int getPageNo() {
		return pageNo;
	}

	public void setPageNo(int pageNo) {
		if (pageNo < 1) {
			pageNo = DEFAULT_PAGE_NO;
		}
		this.pageNo = pageNo;
	}

	public int getPageSize() {
		return pageSize;
	}

	public void setPageSize(int pageSize) {
		if (pageSize < 1) {
			pageSize = DEFAULT_PAGE_SIZE;
		}
		this.pageSize = pageSize;
	}

	public int getTotalCount() {
		return totalCount;
	}

	public void setTotalCount(int totalCount) {
		this.totalCount = totalCount;
	}

	public List<E> getResultList() {
		return resultList;
	}

	public void setResultList(List<E> resultList) {
		this.resultList = resultList;
	}

	public int getPageNaviSize() {
		return pageNaviSize;
	}

	/**
	 * 返回快速导航页码
	 * 
	 * @return
	 */
	public int[] getPageNavis() {
		// 先运算出左,右边界
		int start = 0, end = 0;
		int a = pageNaviSize / 2;
		start = pageNo - a;
		if (pageNaviSize % 2 == 0) {
			end = pageNo + a - 1;
		} else {
			end = pageNo + a;
		}
		// 分三种情况处理
		int totalPages = getTotalPage();
		int[] b = new int[pageNaviSize];
		// 左边界
		if (start < 1) {
			for (int i = 0, step = 1; i < pageNaviSize; i++, step++) {
				if (step <= totalPages) {
					b[i] = step;
				} else {
					break;
				}
			}
		} else if (end > totalPages) {	// 右边界
			for (int i = pageNaviSize - 1, step = totalPages; i >= 0; i--, step--) {
				if (step > 0) {
					b[i] = step;
				} else {
					break;
				}
			}
		} else {	// 中间
			for (int i = 0; i < pageNaviSize; i++) {
				b[i] = start++;
			}
		}
		return b;
	}

	public void setPageNaviSize(int pageNaviSize) {
		if (pageNaviSize < 1) {
			pageNaviSize = DEFAULT_PAGE_NAV_SIZE;
		}
		this.pageNaviSize = pageNaviSize;
	}

	/**
	 * 获得总的页码数量
	 * 
	 * @return
	 */
	public int getTotalPage() {
		if (totalCount % pageSize > 0) {
			return totalCount / pageSize + 1;
		} else {
			return totalCount / pageSize;
		}
	}

	/**
	 * 获取从哪一条记录开始查询
	 * 
	 * @return
	 */
	public int getFirstIndex() {
		return (pageNo - 1) * pageSize;
	}
	
	/**
	 * 获取最后一条记录的下标数(不包含)
	 * 
	 * @return
	 */
	public int getLastIndex() {
		return getFirstIndex() + pageSize;
	}

	/**
	 * 判断是否还有下一页
	 * 
	 * @return
	 */
	public boolean isHasNextPage() {
		return (pageNo + 1) <= getTotalPage();
	}

	/**
	 * 获取下一个页码,在调用之前先调用<code>isHasNextPage()</code>方法进行判断
	 * 
	 * @return
	 */
	public int getNextPage() {
		return pageNo + 1;
	}

	/**
	 * 判断是否还有上一页
	 *
	 * @return
	 */
	public boolean isHasPrePage() {
		return (pageNo - 1) > 0;
	}

	/**
	 * 获取上一个页码,在调用之前先调用<code>isHasPrePage()</code>方法进行判断
	 * 
	 * @return
	 */
	public int getPrePage() {
		return pageNo - 1;
	}
}


  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,实现分页导出Excel通常涉及到两个主要步骤:数据分页和将数据写入Excel文件。Apache POI是一个常用库,用于处理Microsoft Office格式的文档,包括Excel。以下是一个简单的示例,展示了如何使用Apache POI进行分页导出Excel: 1. **数据分页**: - 首先,你需要有一个数据源,如列表或数据库查询结果。例如,如果你的数据在`List<YourDataModel>`,可以计算每页的大小(比如10条记录)并使用`Collections`或数据库API来获取相应页的数据。 ```java List<YourDataModel> dataList = // 获取数据源 int pageSize = 10; int currentPage = 1; // 假设用户选择当前页 int startIndex = (currentPage - 1) * pageSize; List<YourDataModel> pageData = dataList.subList(startIndex, startIndex + pageSize); ``` 2. **创建Excel工作簿和工作表**: - 使用`HSSFWorkbook`创建一个新的Excel工作簿,`HSSFSheet`创建工作表。 ```java HSSFWorkbook workbook = new HSSFWorkbook(); HSSFSheet sheet = workbook.createSheet("Sheet1"); ``` 3. **写入数据到Excel**: - 使用`Row`对象表示行,`Cell`对象表示单元格,将分页数据写入Excel。 ```java Row headerRow = sheet.createRow(0); // 创建表头行 // 填充表头 for (YourDataModel.Field field : YourDataModel.Fields.values()) { Cell cell = headerRow.createCell(field.getIndex()); cell.setCellValue(field.getName()); } for (YourDataModel data : pageData) { Row row = sheet.createRow(sheet.getLastRowNum() + 1); // 创建新行 for (YourDataModel.Field field : data.getFieldValues()) { Cell cell = row.createCell(field.getIndex()); cell.setCellValue(field.getValue()); } } ``` 4. **保存Excel文件**: - 最后,将工作簿写入磁盘文件。 ```java try (FileOutputStream fileOut = new FileOutputStream("output.xlsx")) { workbook.write(fileOut); } catch (IOException e) { e.printStackTrace(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值