使用此分页插件很简单就可以实现多种分页风格!其官方网址为:pager taglib 网址在此下载要用的jar包及实例。现在开始分页:
1.首先导入所需jar包:
2.创建两个工具类:PageMode.java(此类用来生成便利需要的集合,及其总的数据行数) MakePageModel.java
package com.util.pageUtil;
import java.util.List;
/**
* @author ZhangJunpeng
* @declare:此类用来生成便利需要的集合,及其总的数据行数
**/
public class PageMode {
private int total;
private List datas;
public List getDatas() {
return datas;
}
public void setDatas(List datas) {
this.datas = datas;
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
}
------------------------------------------------
package com.util.pageUtil;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import com.school.dao.BaseHibernateDAO;
//import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.sun.org.apache.bcel.internal.generic.NEW;
/**
*@method:MakePageModel
*@author ZhangJunpeng
**/
public class MakePageModel{
/**
*@param offset 当前页数
*@param pagesize 每页显示的行数
*@param objName 传入要传入对象的名字
*@return pageModel pm
**/
private BaseHibernateDAO baseHibernateDAO=new BaseHibernateDAO();
public BaseHibernateDAO getBaseHibernateDAO() {
return baseHibernateDAO;
}
public void setBaseHibernateDAO(BaseHibernateDAO baseHibernateDAO) {
this.baseHibernateDAO = baseHibernateDAO;
}
@SuppressWarnings("unchecked")
public PageMode makePageModel(int offset, int pagesize,String objName) {
String queryCountHql = "select count(*) from "+objName;
List datas=new ArrayList();
int totoalPages=0;
Session session=baseHibernateDAO.getSession();
Transaction transaction=null;
try{
transaction=session.beginTransaction();
Query query = session.createQuery(queryCountHql);
totoalPages = ((Integer)query.uniqueResult()).intValue();
System.out.println(">>>1");
datas = session .createQuery("from "+objName)
.setFirstResult(offset)
.setMaxResults(pagesize)
.list();
System.out.println(">>>2");
transaction.commit();
System.out.println(">>>3"+totoalPages);
}catch (Exception e) {
e.printStackTrace();
transaction.rollback();// TODO: handle exception
}finally{
// session.close();
}
PageMode pm = new PageMode();
pm.setTotal(totoalPages);
pm.setDatas(datas);
return pm;
}
}
3.创建相应的DAO类,实现pageMode的查询(就是返回指定首尾的结果集,及其总的数据数)例如:
/**
* 用于分页显示的查询
* */
public PageMode findAll(int offset, int pagesize){
String queryCountHql = "select count(*) from Admin";
Query query = getSession().createQuery(queryCountHql);
int total = ((Number)query.uniqueResult()).intValue();
List datas = getSession().createQuery("from Admin")
.setFirstResult(offset)
.setMaxResults(pagesize)
.list();
PageMode pm = new PageMode();
pm.setTotal(total);
pm.setDatas(datas);
return pm;
}
如果是struts,或是struts2的话,在action内需要处理如下数据:(STRUTS2示例)
int offset = 0;
AdminDAO adminDAO = new AdminDAO();//需要查询类的DAO
HttpServletRequest request = ServletActionContext.getRequest();
try {
if (request.getParameter("pager.offset") == null) {//pager.offset,taglib标签自带的属性
offset = 0;
} else {
offset = Integer.parseInt(request
.getParameter("pager.offset"));
}
int maxPageItems;//每页显示行数
if(request.getAttribute("maxPageItems")==null){
maxPageItems=10;
}else{
maxPageItems = Integer.parseInt(request.getParameter("maxPageItems"));
}
logger.debug(">>>>"+maxPageItems);
PageMode pm = adminDAO.findAll(offset, maxPageItems);//查询PageMode
request.setAttribute("admins", pm); //设置范围
if (logger.isDebugEnabled()) {
logger.debug("viewAdmin() - end");
}
return "viewAdmin";//转入视图层
} catch (Exception e) {
logger.error("viewAdmin()", e);
logger.error(e.getMessage());
return ERROR;
}
4.根据返回的pageMode可以保存在指定的范围内,然后逃到页面进行显示数据:
在需要显示分页的地方放入:
view plaincopy to clipboardprint?
<!--别忘记引入插件-->
<%@ taglib uri="http://jsptags.com/tags/navigation/pager" prefix="pg" %>
<div>
<pg:pager url="forward!viewAdmin.action" maxPageItems="10" items="${admins.total}" export="currentPageNumber=pageNumber">
<pg:first>
<a href="${pageUrl}" mce_href="${pageUrl}">首页</a>
</pg:first>
<pg:prev>
<a href="${pageUrl }" mce_href="${pageUrl }">上一页</a>
</pg:prev>
<pg:pages>
<c:choose>
<c:when test="${currentPageNumber eq pageNumber}">
<font color="red">${pageNumber }</font>
</c:when>
<c:otherwise>
<a href="${pageUrl }" mce_href="${pageUrl }">${pageNumber }</a>
</c:otherwise>
</c:choose>
</pg:pages>
<pg:next>
<a href="${pageUrl }" mce_href="${pageUrl }">下一页</a>
</pg:next>
<pg:last>
<a href="${pageUrl }" mce_href="${pageUrl }">尾页</a>
</pg:last>
</pg:pager>
</div>
<!--别忘记引入插件-->
<%@ taglib uri="http://jsptags.com/tags/navigation/pager" prefix="pg" %>
<div>
<pg:pager url="forward!viewAdmin.action" maxPageItems="10" items="${admins.total}" export="currentPageNumber=pageNumber">
<pg:first>
<a href="${pageUrl}" mce_href="${pageUrl}">首页</a>
</pg:first>
<pg:prev>
<a href="${pageUrl }" mce_href="${pageUrl }">上一页</a>
</pg:prev>
<pg:pages>
<c:choose>
<c:when test="${currentPageNumber eq pageNumber}">
<font color="red">${pageNumber }</font>
</c:when>
<c:otherwise>
<a href="${pageUrl }" mce_href="${pageUrl }">${pageNumber }</a>
</c:otherwise>
</c:choose>
</pg:pages>
<pg:next>
<a href="${pageUrl }" mce_href="${pageUrl }">下一页</a>
</pg:next>
<pg:last>
<a href="${pageUrl }" mce_href="${pageUrl }">尾页</a>
</pg:last>
</pg:pager>
</div>
参数:url:所要跳转的action maxPageItems:每页显示行数 items: 前面在action中保存的PageMode中的 总数据数
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/10/13/4663223.aspx
分享到:
相关推荐
通过网上搜集资料,实现了一个struts2+hibernate+pager-taglib的分页小例子,大家在运行例子前,请一定要看包里面的readme.txt文件。里面有环境的搭建。
j2ee中struts+hibernate+spring+pager-taglib分页实例 这套解决方案,是按照MVC的模式来做的,基于STRUTS框架。分为三个部分,表现层用的是JSP,其中用了JSTL和pager taglib做分页;控制层就是用的很传统的Action;...
本资源融合了struts+spring+hibernate的集成,并充分运用jsp开源分页标签(pager-taglib)进行了分页。支持多条件的分页查询。由于上传大小限制,本人被迫将所用到的jar包目录删除,所需的几个必备jar包我已留在本...
使用pager-taglib分页,含有多种分页样式,jar包都有,只要导入就可以运行,内附有说明,java 语言的
在Struts中应用标签但一次取数据在页面自动分页的示例(test2.jsp),打开方法: http://localhost:8080/pagertaglib/pageAction.do?pager.offset=0<br>pager-demo.jsp是原标签自带示例索引: ...
pager-taglib 是个很好的jsp分页标签,使用它结合jstl可以实现灵活的分页导航功能。在实际的开发中post方式的提交比较常见,本人做了一个比较通用的基于post方式的一个应用。主要实现一下功能: 1.添加输入跳转、每...
pagerTaglib2.0 struts 分页Demo 对于刚研究分页的来说,可以参考下!
Myeclipse开发struts+hibernate+spring新手入门---环境配置----项目开发示例 Myeclipse开发struts+hibernate+spring小记 开发前准备工作: 1、下载eclipse3.1版本 下载地址: 2、下载Myeclipse插件 下载地址: 3...
pager-taglib分页组建 pager-taglib分页组建 pager-taglib分页组建 pager-taglib分页组建
功能:分页查看表中的记录。 jsp中的分页采用pager-taglib,在底层的分页使用的是hibernate,数据库使用的是oracle。
本资源为轻量级 J2EE 企业应用实战开发笔记,涵盖 Struts、Spring 和 Hibernate 三大框架的整合开发实践。笔记从 JDK 安装和配置环境变量开始,接着介绍了 JSP 的技术原理和使用方法,包括 JSP 注释、声明、表达式、...
Pager-taglib,支持多种风格的分页显示。实际上她是一个Jsp标签库,为在JSP上显示分页信息而设计的一套标签,通过这些标签的不同的组合,会形成多种不一样的分页页面,风格各异,她自带的DEMO就有七种左右的分页风格...
jsp pager-taglib分页资料jsp pager taglib 分页 ppt,很好的分页模版
这是关于paper-taglib分页框架的小小项目,导入myeclipse中部署到服务器可直接运行,包含了两种分页风格:普通样式和谷歌样式,可以在servlet中通过注释切换。
jsp 分页标签。 用于列表自动分页功能
Pager-taglib实际上是一个Jsp标签库,为在JSP上显示分页信息而设计的一套标签,通过这些标签的不同的组合支持多种风格的分页显示。会形成多种不一样的分页页面,风格各异,她自带的DEMO就有七种左右的分页风格,包括...
用于在jsp中进行分页的 pager-taglib包
利用pager-taglib进行查询分页时需要添加该jar包:pager-taglib.jar
该资源系本人工作之余的一个小小案例,希望对大家有所帮助
pager-taglib 安装包和使用手册。