1、分页的bean类PaginationSupport.java
  2、写好后直接在action里面调用,计算当前页显示的数据
  3、写一个公用的jsp页面,直接在需要分页的页面include就可以了。。
  4、运行后式样
  

package com.jrosion.common.util;

import java.util.ArrayList;
import java.util.Vector; /**
* Struts分页
*
* @author Jrosion
* @version 1.0
* @serialData 2006-11-30
*/
public class PaginationSupport { // 每页显示的记录数
public final static int PAGE_SIZE = 12; private int currentPage = 1; // 当前页 private int totalPags = 0; // 总页数 private int totalRows = 0; // 总数据条数 private int pageStartRow; // 每页起始行 private int pageEndRow; // 每页结束行 private boolean isntHaveNextPage = false; // 是否有下一页 private boolean isntHavePreviousPage = false; // 是否有上一页 private Vector navigationPages = new Vector(); private ArrayList currentPageDates = new ArrayList(); // 当前页数据 private String url = ""; // 链接地址 private int nextPage; // 下一页 private int previousPage; // 上一页 private String condition; /**
* 构造分页模型
*
* @param date分页数据
*/
public PaginationSupport(ArrayList paginationDate, int currentPage,
String url) { if (paginationDate != null) { // 总页数
this.totalRows = paginationDate.size(); // 计算总页数
this.totalPags = this.getTotalPages(totalRows); // 当前页
if (currentPage <= 0) {
this.currentPage = 1;
} else if (currentPage > totalPags) {
this.currentPage = totalPags;
} else {
this.currentPage = currentPage;
} // 上一页
this.previousPage = currentPage - 1; // 下一页
this.nextPage = currentPage + 1; // 判断是否还有下页
this.isntHaveNextPage = this.getIsntHaveNextPage(currentPage,
totalPags); // 判断是否有上页
if (currentPage > 1) {
this.isntHavePreviousPage = true;
} else {
this.isntHavePreviousPage = false;
} // 设置数据起始行
int[] row = this.getStartAndEndRow(paginationDate, currentPage,
totalPags, totalRows);
this.pageStartRow = row[0];
this.pageEndRow = row[1]; // 获取当前页需要显示的数据
this.currentPageDates = this.getCurrentPageDate(paginationDate,
pageStartRow, pageEndRow); this.url = url; // 设置导航页
this.navigationPages = this.getNavigationPages(currentPage,
totalPags);
}
} /**
* 根据记录条数进行构造
*
* @param totalRecord
* @param currentPage
* @param url
*/
public PaginationSupport(int totalRecord, int currentPage, String url) { if (totalRecord > 0) { // 总页数
this.totalRows = totalRecord; // 计算总页数
this.totalPags = this.getTotalPages(totalRows); // 当前页
if (currentPage <= 0) {
this.currentPage = 1;
} else if (currentPage > totalPags) {
this.currentPage = totalPags;
} else {
this.currentPage = currentPage;
} // 上一页
this.previousPage = currentPage - 1; // 下一页
this.nextPage = currentPage + 1; // 判断是否还有下页
this.isntHaveNextPage = this.getIsntHaveNextPage(currentPage,
totalPags); // 判断是否有上页
if (currentPage > 1) {
this.isntHavePreviousPage = true;
} else {
this.isntHavePreviousPage = false;
} // 设置数据起始行
int[] row = this.getStartAndEndRow(currentPage);
this.pageStartRow = row[0];
this.pageEndRow = row[1]; this.url = url; // 设置导航页
this.navigationPages = this.getNavigationPages(currentPage,
totalPags);
}
} /**
* 计算总页数
*
* @param totalRows
* @return
*/
public int getTotalPages(int totalRows) { int result = 1; if (totalRows > PAGE_SIZE) {
if ((totalRows % PAGE_SIZE) == 0) {
result = totalRows / PAGE_SIZE;
} else {
result = totalRows / PAGE_SIZE + 1;
}
} return result;
} /**
* 判断是否有下一页
*
* @param currentPages
* @param totalPages
* @return
*/
public boolean getIsntHaveNextPage(int currentPages, int totalPages) { boolean result = false; if (currentPage >= totalPags) {
result = false;
} else {
result = true;
} return result;
} /**
* 返回当前页显示数据的起始行
*
* @param currentPage当前页
* @param totalPags总页数
* @param totalRows总行数
* @return
*/
public int[] getStartAndEndRow(ArrayList paginationDate, int currentPage,
int totalPags, int totalRows) { int[] result = new int[2]; int startRow = PAGE_SIZE * (currentPage - 1); int endRow = 0; if (currentPage == totalPags) {
endRow = totalRows - 1;
} else {
endRow = startRow + PAGE_SIZE - 1;
} result[0] = startRow; result[1] = endRow; return result; } /**
* 返回当前页显示数据的起始行
*
* @param currentPage
* @return
*/
public int[] getStartAndEndRow(int currentPage) { int[] result = new int[2]; int startRow = PAGE_SIZE * (currentPage - 1); int endRow = PAGE_SIZE; result[0] = startRow; result[1] = endRow; return result; } /**
* 初始化导航页面
*
* @return
*/
public Vector initNavigationPages(int totalPages) { Vector result = new Vector(); int loop = 11; if (totalPages < 10) {
loop = totalPages + 1;
} for (int i = 1; i < loop; i++) {
String element = String.valueOf(i).toString();
result.addElement(element);
} return result;
} /**
* 得到导航页面
*
* @param currentPages
* @param totalPages
* @return
*/
public Vector getNavigationPages(int currentPages, int totalPages) { Vector result = new Vector(); if (currentPages > totalPages) {
currentPages = totalPages;
} if (currentPages <= 0) {
currentPages = 1;
} if (totalPages > 10) {
int endPages = currentPages + 10;
int startPages = currentPages;
if (endPages > totalPages) {
int morePages = endPages - totalPages;
startPages = currentPages - morePages + 1;
endPages = totalPages + 1;
} for (int i = startPages; i < endPages; i++) {
String element = String.valueOf(i).toString();
result.addElement(element);
} } else {
result = this.initNavigationPages(totalPages);
} return result;
} /**
* 得到当前页面数据
*
* @param startRow开始行索引
* @param endRow结束行索引
* @return
*/
public ArrayList getCurrentPageDate(ArrayList pageDates, int startRow,
int endRow) { if (pageDates == null || pageDates.size() == 0) {
return null;
} ArrayList result = new ArrayList(); try {
for (int i = startRow; i < endRow + 1; i++) {
result.add(pageDates.get(i));
}
} catch (IndexOutOfBoundsException e) {
System.out.println(e.getMessage());
} return result; } public int getCurrentPage() {
return currentPage;
} public void setCurrentPage(int currentPage) {
this.currentPage = currentPage;
} public boolean isIsntHavePreviousPage() {
return isntHavePreviousPage;
} public void setIsntHavePreviousPage(boolean isntHavePreviousPage) {
this.isntHavePreviousPage = isntHavePreviousPage;
} public int getPageEndRow() {
return pageEndRow;
} public void setPageEndRow(int pageEndRow) {
this.pageEndRow = pageEndRow;
} public int getPageStartRow() {
return pageStartRow;
} public void setPageStartRow(int pageStartRow) {
this.pageStartRow = pageStartRow;
} public int getTotalPags() {
return totalPags;
} public void setTotalPags(int totalPags) {
this.totalPags = totalPags;
} public int getTotalRows() {
return totalRows;
} public void setTotalRows(int totalRows) {
this.totalRows = totalRows;
} public ArrayList getCurrentPageDates() {
return currentPageDates;
} public void setCurrentPageDates(ArrayList currentPageDates) {
this.currentPageDates = currentPageDates;
} public boolean isIsntHaveNextPage() {
return isntHaveNextPage;
} public void setIsntHaveNextPage(boolean isntHaveNextPage) {
this.isntHaveNextPage = isntHaveNextPage;
} public String getUrl() {
return url;
} public void setUrl(String url) {
this.url = url;
} public int getNextPage() {
return nextPage;
} public void setNextPage(int nextPage) {
this.nextPage = nextPage;
} public int getPreviousPage() {
return previousPage;
} public void setPreviousPage(int previousPage) {
this.previousPage = previousPage;
} public Vector getNavigationPages() {
return navigationPages;
} public void setNavigationPages(Vector navigationPages) {
this.navigationPages = navigationPages;
} public String getCondition() {
return condition;
} public void setCondition(String condition) {
this.condition = condition;
} } }

/******************************************/
        service部分代码
/*******************************************/

    public int count(String condition) {
if (condition == "" || condition == null || condition.equals("null")) {
condition = " 1=1 ";
}
return teacherDAO.count(condition);
} public List query(String condition, int startRow, int displayRows) {
if (condition == "" || condition == null || condition.equals("null")) {
condition = " 1=1 ";
}
return teacherDAO.query(condition, startRow, displayRows);
} public HashMap pagination(String condition, String currentPage) { HashMap result = new HashMap(); if (currentPage == "" || currentPage == null
|| currentPage.equals("null")) {
currentPage = "1";
} int page = Integer.valueOf(currentPage).intValue(); int recordCount = this.count(condition); PaginationSupport pagination = new PaginationSupport(recordCount, page,
"/displayTeacher.do"); List pageDate = this.query(condition, pagination.getPageStartRow(),
pagination.getPageEndRow()); result.put("pageData", pageDate); result.put("navigation", pagination); return result;
}
。。。。。

-----------------------------------action调用---------------------

    public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) { List result = teacherService.query(); String page = request.getParameter("page"); if (page == null || page.equals("")) {
page = "1";
} int p = Integer.valueOf(page).intValue(); PaginationSupport pagination = new PaginationSupport(
(ArrayList) result, p, "/displayTeacher.do"); result = pagination.getCurrentPageDates(); request.setAttribute("QueryObject", result); request.setAttribute("page", pagination); return mapping.findForward("teacherIndexGo"); }

  

---公用的jsp页面

<%@ page pageEncoding="gb2312" contentType="text/html;charset=gb2312" %>  

<bean:define id="pages" name="page"/>

<table width="100%" align="center" border="0" cellpadding="0" cellspacing="0">
<TR class="tr">
<TD width="15%" align="right" height="20" valign="baseline">
共:<bean:write name="pages" property="totalPags"/>页/
第<bean:write name="pages" property="currentPage"/>页  
记录总数:<bean:write name="pages" property="totalRows"/>条
<a href="<%=request.getContextPath()%><bean:write name='pages' property='url'/>?page=1">
<img border="0" src="<%=request.getContextPath()%>/skin/<bean:write _fcksavedurl=""<%=request.getContextPath()%>/skin/<bean:write" name="user" property="skin"/>/first.gif"></a> <logic:equal name="pages" property="isntHavePreviousPage" value="true">
<a href="<%=request.getContextPath()%><bean:write name='pages' property='url'/>?page=<bean:write name='pages' property='previousPage'/>">
<img border="0" src="<%=request.getContextPath()%>/skin/<bean:write name="user" property="skin"/>/previous.gif"></a>
</logic:equal> <logic:iterate id="navigation" name="pages" property="navigationPages">
<a href="<%=request.getContextPath()%><bean:write name='pages' property='url'/>?page=<bean:write name='navigation'/>">
<bean:write name="navigation"/></a>
</logic:iterate> <logic:equal name="pages" property="isntHaveNextPage" value="true">
<a href="<%=request.getContextPath()%><bean:write name='pages' property='url'/>?page=<bean:write name='pages' property='nextPage'/>">
<img border="0" src="<%=request.getContextPath()%>/skin/<bean:write name="user" property="skin"/>/next.gif"></a>
</logic:equal>
<a href="<%=request.getContextPath()%><bean:write name='pages' property='url'/>?page=<bean:write name='pages' property='totalPags'/>">
<img border="0" src="<%=request.getContextPath()%>/skin/<bean:write name="user" property="skin"/>/last.gif"></a> <input type="text" size="4" name="iputPage"><input type="button" name="go" value="Go"> </TD>
</TR>
</table>

  

Struts分页的更多相关文章

  1. Hibernate和Struts分页查询

    分页查询数据库方法 /** * 分页查询方法 * @param sql,pageNO,maxResult * @return List */ public List<Object> que ...

  2. Struts分页的一个实现

    在Web应用程序里,分页总让我们开发人员感到很头疼,倒不是因为技术上有多么困难,只是本来和业务没有太多关系的这么一个问题,你却得花不少功夫来处理.要是稍不留神,时不时出点问题就更郁闷了.我现在做的一个 ...

  3. struts分页实现

  4. JQueryPagination分页插件,ajax从struts请求数据

    2017-07-16 学完了struts,做了个关于分页的小例子,用到了JQuery分页插件Pagination,先贴下插件下载地址 http://www.jq22.com/jquery-info13 ...

  5. hibernate和struts实现分页

    仓促把功能进行实现一下  类与类之间也没有进行MVC式分开  重要的是逻辑 记录一下 希望其中的些许代码逻辑对你有用 TUserDaoImpl---dao层的实现 package com.pers.h ...

  6. SSH(Struts 2.3.31 + Spring 4.1.6 + Hibernate 5.0.12 + Ajax)框架整合实现简单的增删改查(包含分页,Ajax 无刷新验证该用户是否存在)

    软件152 余建强 该文将以员工.部门两表带领大家进入SSH的整合教程: 源码下载:http://download.csdn.net/detail/qq_35318576/9877235 SSH 整合 ...

  7. ajax+json模态框中分页(spring+struts+mybatis+easyui分页插件)

    0.业务需求: 点击每个数字的时候可以显示每个对应的详细记录.也就是得点击11的时候拿着开采部与C级去查询.

  8. Struts+Hibernate+jsp页面 实现分页

    dao层数据库代码: package com.hanqi.dao; import java.util.ArrayList; import java.util.List; import org.hibe ...

  9. Struts+jdbc+分页 实例

    根据项目里分页实例,带有注解. package org.tarena.netctoss.dao.impl; import java.sql.Connection; import java.sql.Pr ...

随机推荐

  1. 关于phpmyadmin中添加外键的做法

    今天想加个外键,又不想用命令行,打开PHPMYADMIN看怎么弄,找了半天没有找到添加外键的地方,然后上网搜了一会,发现目前的PHPMYADMIN确实没有这个设置,所以只能手动命令行添加了.   语法 ...

  2. java和javax都是Java的API包,java是核心包,javax的x是extension的意思,也就是扩展包。

    java和javax都是Java的API包,java是核心包,javax的x是extension的意思,也就是扩展包.

  3. 搭建Windows下Java Web开发环境

      概要 1.SSH开发相关软件及开发包下载2.软件安装及相关设置3.最简单的Web程序 1.软件下载 在D盘建一个目录JavaTools,用来存放下载的软件和开发包.(本教程将使用D盘,你也可以使用 ...

  4. Cycling Label

    Cycling Label 来源: github/BBCyclingLabel Licence: Apache 2.0 作者: Bruno de Carvalho 分类: 标签(Label) 平台: ...

  5. SQL数值函数

    /*abs(n)返回参数n所指定数值的绝对值(如果参数值为NULL,则返回结果为NULL,下同).*/--SELECT ABS(-3.14) FROM DUAL; --3.14 /*round(n[, ...

  6. HTML5 格式化、样式、链接、表格

    HTML格式化.样式.链接.表格的使用举例

  7. c - 对数组进行排序(通过指针的指针)

    通过指针的指针,以及一个指针数组,对实际数组元素进行排序,有一个优点,就是排序过程交换的只有指针数组中的值,而不是实际的数组的元素.当实际元素中的对象很大,特别是结构体等类型时,这样做是很有好处. 下 ...

  8. java学习笔记(3):java的工作原理及相关基础

    一.运行机制 如上图所示,图中内容即为Java的运行机制: 1.我们一开始所编写的代码文件存储格式为(如text.java)文件,这就是源程序文件 2.在Java编辑器的作用下,也就是就行了编译,形成 ...

  9. 杂文:AlphaGo 与 Alan Turing

    写于2016 3.8晚 AlphaGo 与 Alan Turing 如果我们可以被称为生物版本的机器人,承载着在上千年或是万年的时间内不断完善的人工智能,并正如行为主义所指出的那样,对不同的刺激做出相 ...

  10. DHTML【2】--HTML

    通过题目,大家已经明确知道,从这一节开始介绍DHTML中的最基础的部分HTML,对于HTML等概念上一节已经做了概述,这一节不再赘余.在学习HTML之前,先告诉大家一个好消息,HTML不难,比C++. ...