java分頁(yè)工具類的使用方法
說(shuō)明:曾經(jīng)在網(wǎng)上看過(guò)花樣繁多的分頁(yè),很多都號(hào)稱如何通用,但很多時(shí)候往往不盡如人意:有在分頁(yè)類中還加入U(xiǎn)RL地址信息的,有在分頁(yè)類中還進(jìn)行分頁(yè)動(dòng)作處理(此動(dòng)作完全屬于操作數(shù)據(jù)庫(kù)方面的事情)的?,F(xiàn)在好了,經(jīng)本人總結(jié)與提煉:
無(wú)論你是否自己手動(dòng)分頁(yè),還是借助了框架進(jìn)行分頁(yè)。此工具類都可以幫助你達(dá)到穩(wěn)定的分頁(yè)效果(包括導(dǎo)航頁(yè)碼功能),而且使用方法也相對(duì)簡(jiǎn)單:好了,廢話少說(shuō),代碼如下:
package test.dao;
import java.util.List;
/**
* 用于分頁(yè)的工具類
* @author 莫取網(wǎng)名
*/
public class Pager<T> {
private List<T> list; //對(duì)象記錄結(jié)果集
private int total = 0; // 總記錄數(shù)
private int limit = 20; // 每頁(yè)顯示記錄數(shù)
private int pages = 1; // 總頁(yè)數(shù)
private int pageNumber = 1; // 當(dāng)前頁(yè)
private boolean isFirstPage=false; //是否為第一頁(yè)
private boolean isLastPage=false; //是否為最后一頁(yè)
private boolean hasPreviousPage=false; //是否有前一頁(yè)
private boolean hasNextPage=false; //是否有下一頁(yè)
private int navigatePages=8; //導(dǎo)航頁(yè)碼數(shù)
private int[] navigatePageNumbers; //所有導(dǎo)航頁(yè)號(hào)
public Pager(int total, int pageNumber) {
init(total, pageNumber, limit);
}
public Pager(int total, int pageNumber, int limit) {
init(total, pageNumber, limit);
}
private void init(int total, int pageNumber, int limit){
//設(shè)置基本參數(shù)
this.total=total;
this.limit=limit;
this.pages=(this.total-1)/this.limit+1;
//根據(jù)輸入可能錯(cuò)誤的當(dāng)前號(hào)碼進(jìn)行自動(dòng)糾正
if(pageNumber<1){
this.pageNumber=1;
}else if(pageNumber>this.pages){
this.pageNumber=this.pages;
}else{
this.pageNumber=pageNumber;
}
//基本參數(shù)設(shè)定之后進(jìn)行導(dǎo)航頁(yè)面的計(jì)算
calcNavigatePageNumbers();
//以及頁(yè)面邊界的判定
judgePageBoudary();
}
/**
* 計(jì)算導(dǎo)航頁(yè)
*/
private void calcNavigatePageNumbers(){
//當(dāng)總頁(yè)數(shù)小于或等于導(dǎo)航頁(yè)碼數(shù)時(shí)
if(pages<=navigatePages){
navigatePageNumbers=new int[pages];
for(int i=0;i<pages;i++){
navigatePageNumbers[i]=i+1;
}
}else{ //當(dāng)總頁(yè)數(shù)大于導(dǎo)航頁(yè)碼數(shù)時(shí)
navigatePageNumbers=new int[navigatePages];
int startNum=pageNumber-navigatePages/2;
int endNum=pageNumber+navigatePages/2;
if(startNum<1){
startNum=1;
//(最前navigatePages頁(yè)
for(int i=0;i<navigatePages;i++){
navigatePageNumbers[i]=startNum++;
}
}else if(endNum>pages){
endNum=pages;
//最后navigatePages頁(yè)
for(int i=navigatePages-1;i>=0;i--){
navigatePageNumbers[i]=endNum--;
}
}else{
//所有中間頁(yè)
for(int i=0;i<navigatePages;i++){
navigatePageNumbers[i]=startNum++;
}
}
}
}
/**
* 判定頁(yè)面邊界
*/
private void judgePageBoudary(){
isFirstPage = pageNumber == 1;
isLastPage = pageNumber == pages && pageNumber!=1;
hasPreviousPage = pageNumber > 1;
hasNextPage = pageNumber < pages;
}
public void setList(List<T> list) {
this.list = list;
}
/**
* 得到當(dāng)前頁(yè)的內(nèi)容
* @return {List}
*/
public List<T> getList() {
return list;
}
/**
* 得到記錄總數(shù)
* @return {int}
*/
public int getTotal() {
return total;
}
/**
* 得到每頁(yè)顯示多少條記錄
* @return {int}
*/
public int getLimit() {
return limit;
}
/**
* 得到頁(yè)面總數(shù)
* @return {int}
*/
public int getPages() {
return pages;
}
/**
* 得到當(dāng)前頁(yè)號(hào)
* @return {int}
*/
public int getPageNumber() {
return pageNumber;
}
/**
* 得到所有導(dǎo)航頁(yè)號(hào)
* @return {int[]}
*/
public int[] getNavigatePageNumbers() {
return navigatePageNumbers;
}
public boolean isFirstPage() {
return isFirstPage;
}
public boolean isLastPage() {
return isLastPage;
}
public boolean hasPreviousPage() {
return hasPreviousPage;
}
public boolean hasNextPage() {
return hasNextPage;
}
public String toString(){
StringBuffer sb=new StringBuffer();
sb.append("[")
.append("total=").append(total)
.append(",pages=").append(pages)
.append(",pageNumber=").append(pageNumber)
.append(",limit=").append(limit)
.append(",isFirstPage=").append(isFirstPage)
.append(",isLastPage=").append(isLastPage)
.append(",hasPreviousPage=").append(hasPreviousPage)
.append(",hasNextPage=").append(hasNextPage)
.append(",navigatePageNumbers=");
int len=navigatePageNumbers.length;
if(len>0)sb.append(navigatePageNumbers[0]);
for(int i=1;i<len;i++){
sb.append(" "+navigatePageNumbers[i]);
}
sb.append(",list.size="+list.size());
sb.append("]");
return sb.toString();
}
}
關(guān)于用法:使用步驟如下:
1).不管是否用了條件查詢,首先count出相應(yīng)的總條數(shù)
2).構(gòu)造一個(gè)Pager類(關(guān)于limit參數(shù)可根據(jù)自身前臺(tái)進(jìn)行取舍)
3).根據(jù)構(gòu)造好的Pager類獲取已經(jīng)自動(dòng)糾正過(guò)的pageNumber參數(shù),-1再乘個(gè)limit,做為實(shí)際要查詢的第一條記錄的位置
4).設(shè)置要查從起始位置開(kāi)始,直到第limit條的所有記錄.(如果手工分頁(yè),則也有可能第二個(gè)參數(shù)是結(jié)尾記錄的位置偏移,具體情況視數(shù)據(jù)庫(kù)而定)
5).將[條件]查詢出的list設(shè)置入pager對(duì)象中并返回.
6).在展現(xiàn)層通過(guò)Servlet或Action或直接拿到這個(gè)pager對(duì)象即可使用,具體如何拼接url的事情,也應(yīng)該交由展現(xiàn)層來(lái)完成即可。
int totalCount=Integer.valueOf(queryCount.uniqueResult().toString()); Pager pager=new Pager(totalCount, pageNumber,limit); queryList.setFirstResult((pager.getPageNumber()-1)*limit); //容錯(cuò)處理 queryList.setMaxResults(limit); pager.setList(queryList.list()); return pager;
上述代碼是使用了hibernate的一個(gè)簡(jiǎn)單示例。如果你是手工分頁(yè),也按使用步驟來(lái)即可。
當(dāng)然了,分頁(yè)可以放在dao層來(lái)完成,也可以放在Service層來(lái)完成。而Servlet或Action則去調(diào)用service層的代碼。個(gè)人認(rèn)為:分頁(yè)其實(shí)也是一種業(yè)務(wù)需要,因此,可以將其放在業(yè)務(wù)層。因?yàn)镈AO層提供相應(yīng)的[條件查詢]list及[條件]統(tǒng)計(jì)count,在業(yè)務(wù)層完全可以根據(jù)自己的需要進(jìn)行方法調(diào)用(只不過(guò)需要按既定的步驟來(lái)罷了,當(dāng)然了,很多時(shí)候,業(yè)務(wù)都是有既定的流程步驟的)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis-Plus條件構(gòu)造器Wrapper應(yīng)用實(shí)例
QueryWrapper是用于查詢的Wrapper條件構(gòu)造器,可以通過(guò)它來(lái)構(gòu)建SELECT語(yǔ)句中的WHERE條件,這篇文章主要介紹了MyBatis-Plus數(shù)據(jù)表操作條件構(gòu)造器Wrapper,需要的朋友可以參考下2023-09-09
如何在Redis中實(shí)現(xiàn)分頁(yè)排序查詢過(guò)程解析
這篇文章主要介紹了如何在Redis中實(shí)現(xiàn)分頁(yè)排序查詢過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
MyBatis利用MyCat實(shí)現(xiàn)多租戶的簡(jiǎn)單思路分享
這篇文章主要給大家介紹了關(guān)于MyBatis利用MyCat實(shí)現(xiàn)多租戶的簡(jiǎn)單思路的相關(guān)資料,文中的多租戶是基于多數(shù)據(jù)庫(kù)進(jìn)行實(shí)現(xiàn)的,數(shù)據(jù)是通過(guò)不同數(shù)據(jù)庫(kù)進(jìn)行隔離,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-06-06
Java中new關(guān)鍵字和newInstance方法的區(qū)別分享
在初始化一個(gè)類,生成一個(gè)實(shí)例的時(shí)候,newInstance()方法和new關(guān)鍵字除了一個(gè)是方法一個(gè)是關(guān)鍵字外,最主要的區(qū)別是創(chuàng)建對(duì)象的方式不同2013-07-07
SpringBoot熔斷機(jī)制之CircuitBreaker詳解
這篇文章主要介紹了SpringBoot熔斷機(jī)制之CircuitBreaker詳解,SpringBoot的熔斷機(jī)制在微服務(wù)架構(gòu)中扮演著重要角色,其中CircuitBreaker是其核心機(jī)制之一,用于防止服務(wù)的異常狀態(tài)影響到整個(gè)系統(tǒng)的運(yùn)作,需要的朋友可以參考下2023-10-10

