Java分页

来源:互联网 发布:网络咨询医生技巧 编辑:程序博客网 时间:2024/06/06 06:33

转载

转载自 一杯凉茶
原帖地址
对原帖进行删减,便于自己使用。

一、创建PageBean存放数据

import java.util.List;public class PageBean<T> {    //已知数据    private int pageNum;    //当前页,从请求那边传过来。    private int pageSize;    //每页显示的数据条数。    private int totalRecord;    //总的记录条数。查询数据库得到的数据    //需要计算得来    private int totalPage;    //总页数,通过totalRecord和pageSize计算可以得来    //开始索引,也就是我们在数据库中要从第几行数据开始拿,有了startIndex和pageSize,    //就知道了limit语句的两个数据,就能获得每页需要显示的数据了    private int startIndex;            //将每页要显示的数据放在list集合中    private List<T> list;    //分页显示的页数,比如在页面上显示1,2,3,4,5页,start就为1,end就为5,这个也是算过来的    private int start;    private int end;    //通过pageNum,pageSize,totalRecord计算得来tatalPage和startIndex    //构造方法中将pageNum,pageSize,totalRecord获得    public PageBean(int pageNum,int pageSize,int totalRecord) {        this.pageNum = pageNum;        this.pageSize = pageSize;        this.totalRecord = totalRecord;        //totalPage 总页数        if(totalRecord%pageSize==0){            //说明整除,正好每页显示pageSize条数据,没有多余一页要显示少于pageSize条数据的            this.totalPage = totalRecord / pageSize;        }else{            //不整除,就要在加一页,来显示多余的数据。            this.totalPage = totalRecord / pageSize +1;        }        //开始索引        this.startIndex = (pageNum-1)*pageSize ;        //显示5页,这里自己可以设置,想显示几页就自己通过下面算法修改        this.start = 1;        this.end = 5;        //显示页数的算法        if(totalPage <=5){            //总页数都小于5,那么end就为总页数的值了。            this.end = this.totalPage;        }else{            //总页数大于5,那么就要根据当前是第几页,来判断start和end为多少了,            this.start = pageNum - 2;            this.end = pageNum + 2;            if(start < 0){                //比如当前页是第1页,或者第2页,那么就不如和这个规则,                this.start = 1;                this.end = 5;            }            if(end > this.totalPage){                //比如当前页是倒数第2页或者最后一页,也同样不符合上面这个规则                this.end = totalPage;                this.start = end - 5;            }        }    }//get、set方法。    public int getPageNum() {        return pageNum;    }    public void setPageNum(int pageNum) {        this.pageNum = pageNum;    }    public int getPageSize() {        return pageSize;    }    public void setPageSize(int pageSize) {        this.pageSize = pageSize;    }    public int getTotalRecord() {        return totalRecord;    }    public void setTotalRecord(int totalRecord) {        this.totalRecord = totalRecord;    }    public int getTotalPage() {        return totalPage;    }    public void setTotalPage(int totalPage) {        this.totalPage = totalPage;    }    public int getStartIndex() {        return startIndex;    }    public void setStartIndex(int startIndex) {        this.startIndex = startIndex;    }    public List<T> getList() {        return list;    }    public void setList(List<T> list) {        this.list = list;    }    public int getStart() {        return start;    }    public void setStart(int start) {        this.start = start;    }    public int getEnd() {        return end;    }    public void setEnd(int end) {        this.end = end;    }}

二、在service层编写业务逻辑代码

public static PageBean<UserManage> getUserManage(String username,int pageNum,int pageSize) {        ManageDao dao=new ManageDaoImp();        //获取数据总数        int totalRecord=dao.getUserManageNum(username);        //new PageBean对象        PageBean<UserManage> pBean=new PageBean<>(pageNum, pageSize, totalRecord);        //获取PageBean对象的starIndex        int startIndex=pBean.getStartIndex();        //设置每页数据        pBean.setList(dao.getUserManage(username, startIndex, pageSize));        return pBean;    }

三、Servlet中编写控制代码

原帖 将pageBean添加到request域中(未做尝试)

//获取当前是第几页int pageNum=Integer.valueOf((String)request.getParameter("pageNum"));//每页显示条数int pageSize=10;//获取pageBean 添加进sessionPageBean<UserManage> pageBeanU= ManageService.getUserManage((String)request.getSession().getAttribute("username"), pageNum, pageSize);request.getSession().setAttribute("pageBeanU", pageBeanU);request.getRequestDispatcher("WEB-INF/OA/page/AccountManagement.jsp").forward(request, response);

四、JSP中显示数据,构建分页导航

<c:forEach items="${pageBeanU.list}" var="obj">    <label >        <ul class="list_b">            <li class="b15"><span class="mylabel"></span><input type="radio" name="myuser" value="${obj.username}"><span>${obj.username}</span></li>            <li class="b25"><span class="mylabel">${obj.password}</span></li>            <li class="b60"><span class="mylabel">${obj.department_name}</span></li>       </ul>   </label></c:forEach>

分页导航

<a href="UserServlet?pageNum=1">首页</a><%--如果当前页为第一页时,就没有上一页这个超链接显示 --%><c:if test="${pageBeanU.pageNum ==1}">   <c:forEach begin="${pageBeanU.start}" end="${pageBeanU.end}" step="1" var="i">       <c:if test="${pageBeanU.pageNum == i}">           <a class="on">${i}</a>       </c:if>                       <c:if test="${pageBeanU.pageNum != i}">           <a href="UserServlet?pageNum=${i}">${i}</a>                                               </c:if>                           </c:forEach>   <a href="UserServlet?pageNum=${pageBeanU.pageNum+1}">下一页</a>                    </c:if><%--如果当前页不是第一页也不是最后一页,则有上一页和下一页这个超链接显示 --%><c:if test="${pageBeanU.pageNum > 1 && pageBeanU.pageNum < pageBeanU.totalPage}">    <a href="UserServlet?pageNum=${pageBeanU.pageNum-1}">上一页</a>    <c:forEach begin="${pageBeanU.start}" end="${pageBeanU.end}" step="1" var="i">            <c:if test="${pageBeanU.pageNum == i}">            <a class="on">${i}</a>        </c:if>                    <c:if test="${pageBeanU.pageNum != i}">             <a href="UserServlet?pageNum=${i}">${i}</a>                                                </c:if>                            </c:forEach>    <a href="UserServlet?pageNum=${pageBeanU.pageNum+1}">下一页</a>    </c:if><%-- 如果当前页是最后一页,则只有上一页这个超链接显示,下一页没有 --%><c:if test="${pageBeanU.pageNum == pageBeanU.totalPage && rolePage.pageNum!=1 }">   <a href="UserServlet?pageNum=${pageBeanU.pageNum-1}">上一页</a>   <c:forEach begin="${pageBeanU.start}" end="${pageBeanU.end}" step="1" var="i">       <c:if test="${pageBeanU.pageNum == i}">            <a class="on">${i}</a>       </c:if>       <c:if test="${pageBeanU.pageNum != i}">            <a href="UserServlet?pageNum=${i}">${i}</a>                                               </c:if>                   </c:forEach></c:if><%--尾页 --%><a href="UserServlet?pageNum=${pageBeanU.totalPage}">尾页</a>