控件类实现了对分页变量的处理,js实现分页的显示

转载 2006年05月19日 03:00:00
以下是.net控件代码:
  本帖相关代码   [全显模式]
using System;
using System.Web;
using System.Web.UI;
using System.Text.RegularExpressions;

namespace cnVery.bbs
{
    public class Pager : Control
    {
        //属性
        private string url;
        public string Url {
            get {
                return url;
            }
            set {
                url = value;
            }
        }
        private int page;
        new public int Page {
            get {
                return page;
            }
            set {
                page = value;
            }
        }
        private int maxpage;
        public int MaxPage {
            get {
                return maxpage;
            }
            set {
                maxpage = value;
            }
        }
        private int per;
        public int Per {
            get {
                return per;
            }
            set {
                per = value;
            }
        }
        private int total;
        public int Total {
            get {
                return total;
            }
            set {
                total = value;
            }
        }

        //构造器
        public Pager()
        {
            this.url        = "";
            this.page        = 1;
            this.maxpage    = 1;
            this.per        = 20;
            this.total        = 0;
        }
        public Pager(string url, int page, int maxpage, int per, int total)
        {
            this.url        = url;
            this.page        = page;
            this.maxpage    = maxpage;
            this.per        = per;
            this.total        = total;
        }

        //方法
        private string Get(string key)
        {
            if (Context.Request.QueryString[key] == null) {
                return "";
            } else {
                return Context.Request.QueryString[key];
            }
        }
        public bool IsNumeric(object obj)
        {
            if (Regex.IsMatch(obj.ToString(), "^[0-9]+$")) {
                return true;
            } else {
                return false;
            }
        }
        public bool GetTotal()
        {
            if (IsNumeric(Get("total"))) {
                total = int.Parse(Get("total"));
                return true;
            } else {
                return false;
            }
        }
        public void Calculate()
        {
            if (IsNumeric(Get("page"))) {
                page = int.Parse(Get("page"));
            } else {
                page = 1;
            }
            maxpage = Convert.ToInt16(total / per);
            if (total % per != 0) {
                maxpage++;
            }
            if (maxpage < 1) {
                maxpage = 1;
            }
            if (page < 1) {
                page = 1;
            } else if (page > maxpage) {
                page = maxpage;
            }
            url += "total=" + total + "&";
        }


        //拼装
        public string GetHalfContent()
        {
            string s = "<script language='javascript'>/r/n";
            s += ("    var s = pager('"+ url + "', " + page + ", " + maxpage + ", " + total + ", " + per + ", false);/r/n");
            s += "    document.write(s);/r/n";
            s += "</script>";
            return s;
        }
        public string GetContent()
        {
            string s = "<script language='javascript'>/r/n";
            s += ("    var s = pager('"+ url + "', " + page + ", " + maxpage + ", " + total + ", " + per + ", true);/r/n");
            s += "    document.write(s);/r/n";
            s += "</script>";
            return s;
        }


        //输出
        protected override void Render(HtmlTextWriter output)
        {
            output.Write(GetContent());
        }
    }
}


以下是js代码部分:
  本帖相关代码   [全显模式]
function pager(url, page, maxpage, total, per, countsvisible)
{
    var s;
    if (countsvisible) {
        s = "<div style='float:left'>";
    } else {
        s = "<div>";
    }
    s += ("<font class='t3' style='font-family:Courier New;font-size:12px'>");
    if (page == 1) {
        s += ("首页 上页 <b>");
    } else {
        s += ("<a href='" + url + "page=1'>首页</a> ");
        s += ("<a href='" + url + "page=" + (page-1) + "'>上页</a> <b>");
    }
    var j = (page-5<1) ? 1 : page-5;
    var k = (page+5>maxpage) ? maxpage : page+5;
    if (j > 1) {
        s += " <a href='" + url + "page=1'>1</a> ... ";
    }
    var i;
    for(i=j; i<k+1; i++) {
        if (page == i) {
            s += ("<span class='t2'>" + i + "</span> ");
        } else {
            s += ("<a href='" + url + "page=" + i + "'>" + i + "</a> ");
        }
    }
    if (maxpage > k) {
        s += " ... <a href='" + url + "page=" + maxpage + "'>" + maxpage + "</a> ";
    }
    if (page == maxpage) {
        s += ("</b>下页 末页");
    } else {
        s += ("</b><a href='" + url + "page=" + (page+1) + "'>下页</a> ");
        s += ("<a href='" + url + "page=" + maxpage + "'>末页</a>");
    }
    s += ("</font></div>");
    if (countsvisible)
    {
        s += ("<div style='float:right'>");
        s += ("总记录:<span class='t2'>" + total + "</span> ");
        s += ("总页数:<span class='t2'>" + maxpage + "</span> ");
        s += ("每页:<span class='t2'>" + per + "</span></div>");
    }
    return s;
}

相关文章推荐

使用ThreadLocal对分页逻辑的封装处理

ThreadLocal设计模式,线程局部变量,因为每一次请求都对应一个线程,把初始化的分页数据放在这个局部变量中,当用到时,可以直接从当前线程中获取。原理同HibernateOpenSessionIn...

对分页,分段的一些理解

分段 是处理器固有 机制,即使是平坦模型也需要 段地址+偏移量 形成线性地址。 分段好处: 1.8086 16位地址只能访问64k,但是为了访问1mb内存,出现了分段,段地址*16+偏移地址 = ...

Ext 2.0使用:对分页Ext.PagingToolbar的扩展

Ext 2.0使用:对分页Ext.PagingToolbar的扩展在Ext的原有分页控件中,服务器端方法是根据传入的起始数据记录号(start),和显示多少条记录(limit)来返回当前页记录的。有时...

SQL Server2012 T-SQL对分页的增强尝试

简介     SQL Server 2012中在Order By子句之后新增了OFFSET和FETCH子句来限制输出的行数从而达到了分页效果。相比较SQL Server 2005/2008的ROW_...

PagedDataSource类 实现DataList控件 分页

用PagedDataSource类实现DataList控件的数据分页 Asp.net提供了三个功能强大的列表控件:GridView、DataList和Repeater控件,相对GridView,Da...

仿淘宝分页按钮效果简单美观易使用的JS分页控件

仿淘宝分页按钮效果简单美观易使用的JS分页控件 博客分类:  web前端 css javascript 分页按钮控件 css分页控件  最新版本代码请移步到https:/...

js 日历控件My97DatePicker,js分页

  • 2010年03月27日 18:01
  • 36KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:控件类实现了对分页变量的处理,js实现分页的显示
举报原因:
原因补充:

(最多只允许输入30个字)