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 +"页 ";
pagestr+=page>1 ? "<a href=\""+ query_string + "?page=1\">首页</a> <a href=\""+ query_string +"?page="+ pre +"\">上一页</a>": "首页 上一页";
//中间页处理,这个增加时间复杂度,减小空间复杂度
for(int i=startcount;i<=endcount;i++)
{
pagestr+=page==i?" <font color=\"#ff0000\">"+i+"</font>":" <a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
}
pagestr+=page!=allpage ? " <a href=\""+ query_string+"?page="+ next +"\">下一页</a> <a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页";
return pagestr;
}
/// 类似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 +"页 ";
pagestr+=page>1 ? "<a href=\""+ query_string + "?page=1\">首页</a> <a href=\""+ query_string +"?page="+ pre +"\">上一页</a>": "首页 上一页";
//中间页处理,这个增加时间复杂度,减小空间复杂度
for(int i=startcount;i<=endcount;i++)
{
pagestr+=page==i?" <font color=\"#ff0000\">"+i+"</font>":" <a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
}
pagestr+=page!=allpage ? " <a href=\""+ query_string+"?page="+ next +"\">下一页</a> <a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页";
return pagestr;
}
备注:文章发表被许多网站转载,我搜索后发现有的同志加上了分页的存储过程,其实我的其他文章里也转了那样的分页存储过程。
我把别人改进后的版本转过来,地址如下:http://blog.csdn.net/lcfgaoyong/archive/2006/04/20/670806.aspx
你可以看到这个版本的演变过程。
其实这个函数的最初始的原作者是youreyes,是php版的,我把它翻译成了c#版。
本文版权属于王传炜所有,首发http://www.cnblogs.com/,转载请注明出处。