`
aa00aa00
  • 浏览: 332987 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
文章分类
社区版块
存档分类
最新评论

通用分页:pager taglib执行分页(本例采用struts2+hibernate)

阅读更多

使用此分页插件很简单就可以实现多种分页风格!其官方网址为: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+pager-taglib 实现分页小例子

    总结来说,这个例子展示了如何在Struts2框架下结合Hibernate和Pager-taglib实现一个基本的分页功能。通过理解Action类的职责、Hibernate的数据访问机制以及Pager-taglib的使用方法,我们可以轻松地在实际项目中实现...

    j2ee中struts+hibernate+spring+pager-taglib分页实例

    ### j2ee中struts+hibernate+spring+pager-taglib分页实例 #### 概述 在Java企业级应用开发中,Struts、Hibernate、Spring与Pager Taglib经常被联合使用,以构建高性能、高灵活性的应用系统。本文将详细介绍如何...

    ssh+分页(pager-taglib)

    本资源融合了struts+spring+hibernate的集成,并充分运用jsp开源分页标签(pager-taglib)进行了分页。支持多条件的分页查询。由于上传大小限制,本人被迫将所用到的jar包目录删除,所需的几个必备jar包我已留在本...

    jsp , strusts ,hibernate,pager-taglib实现的分页显示

    【标题】"jsp , struts ,hibernate,pager-taglib实现的分页显示"涉及的知识点主要包括四个关键部分:JSP(JavaServer Pages)、Struts、Hibernate以及Pager-Taglib分页库。这些技术都是Java Web开发中的核心组件,...

    ssh+pager taglib分页实现

    在IT行业中,SSH(Spring、Struts、Hibernate)是一个经典的Java Web开发框架组合,而`pager`则是分页功能的一种实现。在这个主题中,我们将深入探讨如何在SSH框架下使用`pager`标签库来实现高效的分页显示。首先,...

    使用pager-taglib实现分页显示的详细步骤

    本文将详细介绍如何利用`pager-taglib`结合SSH(Struts、Spring、Hibernate)框架实现从前端到后端的分页功能。 #### 一、准备工作 在开始之前,确保项目环境中已经引入了Struts、Spring、Hibernate以及`pager-...

    pager-taglib实现Google分页

    本主题将深入探讨如何利用pager-taglib库实现类似于Google的高效分页效果,该库是基于Spring、Struts和Hibernate(SSH)框架的。下面我们将详细讲解相关知识点。 首先,** pager-taglib **是一个自定义的JSP标签库...

    SSHConformity【display标签和taglib标签缺架包】,ssh整合,分页,display标签,pager-taglib标签

    在本主题中,我们将重点讨论SSH整合、分页功能以及Display Tag和Pager Taglib这两个常用的标签库。 首先,SSH(Spring、Struts和Hibernate)是Java Web开发中的三大核心技术。Spring提供了依赖注入和面向切面编程,...

    pager-taglib-2.0

    "pager-taglib-2.0" 可以无缝集成到Spring MVC、Struts等主流Java Web框架中,与ORM框架如Hibernate、MyBatis配合使用,简化数据分页的处理流程。 7. **注意事项** - 要确保正确配置了Taglib的URI,否则可能会...

    OA pagertaglib ssh2 增删改查

    本项目以“OA pagertaglib ssh2 增删改查”为主题,涉及到的关键技术包括SSH2框架、PagerTaglib分页库以及增删改查的基础操作。 首先,SSH2是指Spring、Struts2和Hibernate这三个开源框架的组合,它们是Java Web...

    struts hibernate 分页

    分页组件通常是一个独立的库,如DisplayTag、PagerTaglib或自定义的JSP标签库。这些组件提供了一套预定义的标签,简化了在JSP页面上创建分页链接的过程。例如,DisplayTag可以自动处理分页链接、当前页状态等复杂...

    SSHConformity【display标签和taglib标签】,display标签,pager-taglib标签

    SSHConformity是一个基于Spring、Struts和Hibernate的开源项目,它集成了多种标签库,以简化Web开发过程。在SSHConformity中,`display标签`和`taglib标签`是两个重要的组件,主要用于页面展示和数据分页。 1. **...

    struts2 spring hibernate所需jar包

    struts2+spring2.5+hibernate3.2整合所需的所有jar包,并额外包含了dwr.jar、分页组件pager-taglib、绘图组件jfreechart.jar、Excel解析工具包jxl.jar、数据库连接池工具包proxool.jar

    Pager Tag Lib分页操作源码

    本篇文章将深入探讨Pager Tag Lib在SSH2(Spring、Struts2、Hibernate2)框架中结合JSTL的使用方法和实现原理。 首先,SSH2是一个强大的企业级应用开发框架,Spring负责依赖注入和事务管理,Struts2作为MVC框架处理...

    java学生成绩管理系统源码数据库 MySQL源码类型 WebForm

    JAVA学生成绩管理系统源码 开发语言:JAVA, 框架:SSH+Mysql+jsp (struts2 + spring + hibernate) 带有Mysql数据库和漂亮的后台管理功能 ... 分页使用的是pager-taglib框架 7. 后台登陆使用的是frameset框架

    S2SH整合pager-taglibs示例

    本示例主要关注的是如何在Struts2框架中整合`pager-taglibs`,它是一个强大的分页标签库,能够帮助开发者在页面上轻松实现数据的分页展示,提升用户体验。`pager-taglibs`使得在JSP页面中处理大量数据变得更加简洁...

    OA 项目 SSH2 增删改查

    本项目基于SSH2框架实现,SSH2是Struts2、Hibernate和Spring的集成,这是一个经典的Java Web开发技术栈。下面我们将深入探讨SSH2框架以及在OA项目中的应用。 1. **Struts2**:Struts2是一个MVC(Model-View-...

    标签: OA 项目 SSH2 增删改查

    本项目采用SSH2框架进行开发,SSH2是指Spring、Struts2和Hibernate这三个开源框架的组合,它们分别是应用层、表现层和持久层的技术解决方案。 Spring框架是Java企业级应用的核心组件,提供了依赖注入(Dependency ...

    SSH集成所需要的jar包

    - `pager-taglib.jar`: 这个库提供了分页标签,方便在JSP页面中实现数据的分页显示。 这些jar包共同构成了SSH集成的基础,使得开发者可以构建出结构清晰、易于维护的Java Web应用程序。通过Struts处理用户请求,...

Global site tag (gtag.js) - Google Analytics