jsp分页控件

1.PagingTag.java

 

package com.cn.cosoft.util.taglibs;

import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.TagSupport;

/** */
/**
 * 自定义的分页标签
 *
 * @author 马万林
 *
 */
public class PagingTag extends TagSupport {

    private String url = null;
    private int pageIndex;
    private int pageMax;

    public void setUrl(String url) {
        this.url = url;
    }

    public String getUrl() {
        return this.url;
    }

    public void setPageIndex(int pageIndex) {
        this.pageIndex = pageIndex;
    }

    public int getPageIndex() {
        return this.pageIndex;
    }

    public void setPageMax(int pageMax) {
        this.pageMax = pageMax;
    }

    public int getPageMax() {
        return this.pageMax;
    }


    @Override
    public int doStartTag() throws JspException {
        String str = "";
        if (pageIndex == 1) {
            str += "首页 上一页 ";
        } else {
            str += " <a href='" + url + "pageIndex=1'>首页</a> "
                    + "<a href='" + url + "pageIndex=" + (pageIndex - 1) + "'>上一页</a> ";
        }
        if (pageIndex / 6 < 1.0 || pageMax < 10) {
            for (int i = 1; i <= 9; i++) {
                if (i <= pageMax) {
                    if (pageIndex != i) {
                        str += "<a href='" + url + "pageIndex=" + i + "'>[" + i + "]</a> ";
                    } else {
                        str += "  " + i + " ";
                    }
                }
            }
        } else if (pageIndex / 6 >= 1.0 && pageMax >= 10) {
            int fri = 0;
            int max = 0;
            if (pageMax - pageIndex > 4) {
                fri = pageIndex - 4;
                max = pageIndex + 4;
            } else {
                fri = pageMax - 8;
                max = pageMax;
            }
            for (int i = fri; i <= max; i++) {
                if (i <= pageMax) {
                    if (pageIndex != i) {
                        str += "<a href='" + url + "pageIndex=" + i + "'>[" + i + "]</a> ";
                    } else {
                        str += "  " + i + " ";
                    }
                }
            }
        }
        if (pageIndex == pageMax || pageMax < 2) {
            str += "下一页 尾页";
        } else {
            str += "<a href='" + url + "pageIndex=" + (pageIndex + 1) + "'>下一页</a> "
                    + "<a href='" + url + "pageIndex=" + pageMax + "'>尾页</a>";
        }
        try {
            if (str != "") {
                pageContext.getOut().write(str);
            }
        } catch (Exception e) {
            throw new JspException(e);
        }
        return EVAL_PAGE;
    }
}

 2.pagingTag.tld

 

<?xml  version="1.0"  encoding="utf-8"  ?>
 <!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<taglib>
    <tlib-version>1.0</tlib-version>
    <jsp-version>1.2</jsp-version>
    <short-name>pagingTag</short-name>
    <!--OutputTag-->
    <tag>
        <name>pageOut</name>
        <tag-class>com.cn.cosoft.util.taglibs.PagingTag</tag-class>
        <body-content>empty</body-content>
        <attribute>
            <name>url</name>
            <required>true</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>pageIndex</name>
            <required>true</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
        <attribute>
            <name>pageMax</name>
            <required>true</required>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
    </tag>
</taglib>

 3.index.jsp

 

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@taglib uri="/WEB-INF/pagingTag.tld" prefix="pt"%>

<html>
    <body >

  <pt:pageOut url="当前页面路径?" pageIndex="当前分页页码"
                                pageMax="总的分页页码" ></pt:pageOut>

</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JspPageControlor分页插件使用说明<br>1、次插件将数据库查询和分页操作分离开,在查询的时候,不管采用什么设计模式,都必须实现<br>PageListener接口。<br>2、接口里面包含四个方法<br>(1)、public List doSelect(int recordStart,int sizePage),参数recordStart表示从第几条<br>记录开始查询。参数sizePage表示一次查几条记录。返回一个list对象(该list对象可以是<br>一个记录集,也可以是一个POJO类对象)<br>(2)、public int getCount(),查询该表中的记录总数,返回一个int对象。<br>(3)、public void close(),放置所有关闭操作的方法。<br>3、调用页面,必须添加PageListener监听器,即实现addPageListener(Object)方法,参数为操作<br>数据库类的对象。<br>4、用getRecord()方法获取存有记录的list对象;<br>用getFirstPage()方法获取'首页'的标记;<br>用getPageUp()方法获取'上一页'的标记;<br>用getPageDown()方法获取'下一页'的标记;<br>用getLastPage()方法获取'末页'的标记;<br>用getPageForward()方法获取'跳转到第几页'的输入框标记;<br>用getCountRecord()方法获取总记录数;<br>用getCountPage()方法获取总页数;<br>用getCurrentPage()方法获取当前页数;<br>5、如果需要把上一页,下一页等标记换成图片,则只需调用<br>setPageDown('图片路径+图片名'),<br>setPageUp('图片路径+图片名'),<br>setFirstPage('图片路径+图片名'),<br>setLastPage('图片路径+图片名');<br>详细操作请查看帮助文档和具体实现案例;<br><br>PageControlor分页插件(次插件仅支持jsp)<br>包含3个文件:<br>PageControlor分页插件;<br>分页的帮助文档;<br>分页插件使用案例;<br><br>运行使用具体案例时,须注意以下几点:<br>1、运行环境为jdk(1.4以上),Tomcat(5.0以上),mysql(5.0.x);<br>2、运行时须改动init.properties,把数据库名,用户名和密码改称自己数据库的设置;<br>3、将news.sql文件导入到您的mysql服务器里面。<br><br>开发者:千里web架构实验室成员--刘捷<br>2007年10月29日 <br>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值