zoukankan      html  css  js  c++  java
  • c#实现google样式的分页

              
                做一个项目,用到了DATALIST,由于分页的需求,手动写了分页的函数。个人觉得GOOGLE的分页很不错,上网查了下资料,修改了下。
                这里没有涉及到数据的分页读取,只是返回一个带HTML代码的分页样式(字符串),可以用label在页面显示,也可以用this.Controls.Add(new LiteralControl(string));方法加入到页面控件中。
              
        /// <summary>
            
    /// 类似GOOGLE的分页函数,王传炜,资料参考http://www.phpx.com/happy/viewthread.php?tid=99280&extra=&page=2,谢谢YourEyes
            
    /// </summary>
            
    /// <param name="total">总记录数</param>
            
    /// <param name="per">每页记录数</param>
            
    /// <param name="page">当前页数</param>
            
    /// <param name="query_string">Url参数</param>

            private string pagination(int total,int per,int page,string query_string)
            
    {
                
    int allpage=0;
                
    int next=0;
                
    int pre=0;
                
    int startcount=0;
                
    int endcount=0;
                
    string pagestr="";

                
    if(page<1){page=1;}
                
    //计算总页数
                if (per != 0)
                
    {
                    allpage 
    = (total / per);
                    allpage 
    = ((total % per) != 0 ? allpage + 1 : allpage);
                    allpage 
    = (allpage == 0 ? 1 : allpage);
                }

                next
    =page+1;
                pre
    =page-1;
                startcount
    =(page+5)>allpage?allpage-9:page-4;//中间页起始序号
                
    //中间页终止序号
                endcount = page<5 ? 10 : page+5;
                
    if(startcount<1{startcount=1;} //为了避免输出的时候产生负数,设置如果小于1就从序号1开始
                if(allpage<endcount){endcount=allpage;}//页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内
                pagestr=""+ allpage +"页&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;";
                
                pagestr
    +=page>1 ?  "<a href=\""+ query_string + "?page=1\">首页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ pre +"\">上一页</a>""首页 上一页";
                 
    //中间页处理,这个增加时间复杂度,减小空间复杂度
                 for(int i=startcount;i<=endcount;i++)
                 

                     pagestr
    +=page==i?"&nbsp;&nbsp;<font color=\"#ff0000\">"+i+"</font>":"&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
                 }

                 pagestr
    +=page!=allpage ? "&nbsp;&nbsp;<a href=\""+ query_string+"?page="+ next +"\">下一页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页";

                
    return pagestr;

               
            }

            

      备注:文章发表被许多网站转载,我搜索后发现有的同志加上了分页的存储过程,其实我的其他文章里也转了那样的分页存储过程。
       我把别人改进后的版本转过来,地址如下:http://blog.csdn.net/lcfgaoyong/archive/2006/04/20/670806.aspx
      你可以看到这个版本的演变过程。
      其实这个函数的最初始的原作者是youreyes,是php版的,我把它翻译成了c#版。
  • 相关阅读:
    Robotium 测试方法
    T-SQL—理解CTEs
    SQLServer复制(二)--事务代理作业
    数据库复制(一)--复制介绍
    小议如何使用APPLY
    优化SQLServer——表和分区索引(二)
    关于UNPIVOT 操作符
    XML 在SQLServer中的使用
    列存储索引1:初识列存储索引
    T-SQL性能调整(一)--编译和重新编译
  • 原文地址:https://www.cnblogs.com/wangergo/p/359162.html
Copyright © 2011-2022 走看看