一个分页页码控件

简介:
  public class PageList : CompositeControl
    {
        protected override HtmlTextWriterTag TagKey
        {
            get
            {
                return HtmlTextWriterTag.Span;
            }
        }
        public PageList(int pageIndex, int pageSize, int maxPageCount, int count): base()
        {   
            //page count
            int pageCount = count / pageSize;
            if (count % pageSize != 0) pageCount++;
            //reset pageIndex
            if(pageIndex <0)pageIndex =0;
            if(pageIndex >pageCount )pageIndex = pageCount ;
            //url
            string url = Favor.CurrentPage.Request.RawUrl;
            if (url.Contains("?")) url.Remove(url.LastIndexOf('?'));
            url += "?pageIndex=";
            //startIndex,endIndex
            int startIndex = 0, endIndex = 0;
            GetPageArea(ref startIndex, ref endIndex, pageIndex, pageSize, pageCount);

            List<Control> cs = new List<Control>();

            //head links
            if (startIndex != 0)
            {
                //<<
                HyperLink first = new HyperLink();
                first.NavigateUrl = url + "0";
                first.Text = "<<";
                cs.Add(first);
                //...
                HyperLink dotted = new HyperLink();
                dotted.Text = "...";
                dotted.NavigateUrl = url + (pageIndex - pageSize).ToString();
                cs.Add(dotted);
            }

            //middle links
            for (int i = startIndex; i <= endIndex; i++)
            {
                HyperLink lk = new HyperLink();
                lk.Text = (i + 1).ToString();
                lk.NavigateUrl = url + i.ToString();

                if (i == pageIndex) lk.CssClass = "selected";
                cs.Add(lk);
            }

            //tail links
            if (endIndex != 0)
            {
                //...
                HyperLink dotted = new HyperLink();
                dotted.Text = "...";
                dotted.NavigateUrl = url + (pageIndex + pageSize).ToString();
                cs.Add(dotted);
                //>>
                HyperLink end = new HyperLink();
                end.NavigateUrl = url + (pageCount - 1).ToString();
                end.Text = ">>";
                cs.Add(end);
            }
            foreach (Control c in cs)
            {
                Controls.Add(c);
            }
            
        }
本文转自today4king博客园博客,原文链接:http://www.cnblogs.com/jinzhao/archive/2009/02/25/1398236.html,如需转载请自行联系原作者
相关文章
|
1月前
|
SQL Oracle 关系型数据库
分页
分页
26 1
|
4月前
|
SQL Java 关系型数据库
3.分页
本文介绍了MyBatis中的分页技术,包括四种主要方法:自带`RowBounds`分页、第三方插件PageHelper、SQL分页以及数组分页。`RowBounds`通过内存处理所有查询结果实现分页;PageHelper插件能智能识别数据库类型并自动添加相应的分页关键字;SQL分页直接利用SQL语句中的`LIMIT`或类似关键字;数组分页则是查询所有数据后使用`subList`进行切片。此外,还提到了自定义拦截器实现分页的方式。物理分页虽在小数据量场景下效率较低,但在大数据量时更为适用,优于逻辑分页。
|
7月前
分页实现
分页实现
39 0
|
7月前
|
SQL Oracle 关系型数据库
3.分页
3.分页
|
SQL Java 数据库连接
分页的实现
分页的实现
|
Java 数据库连接 数据库
分页之页面页码列表计算 | 学习笔记
快速学习分页之页面页码列表计算
280 0