我这里封装在用户控件里。你也可以封装在类文件中。自己定义:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Text;
namespace HHWeb.UserControl
{
public partial class Paging : System.Web.UI.UserControl
{
public StringBuilder PagingControlInfo = new StringBuilder();
protected void Page_Load(object sender, EventArgs e)
{
GetPaging();
}
void GetPaging()
{
//判断如果当前页为负数或者零时,NowPage=1
if (NowPage <= 0)
NowPage = 1;
//判断如果当前页大于总页数时,NowPage=PageCount
int PageCount = GetPageCount();
if (NowPage > PageCount)
NowPage = PageCount;
//首页和上一页()
if (NowPage != 1)
{
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage=1\">首页</a>");
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage=" + (NowPage - 1) + "\">上一页</a>");
}
//如果分页总页数小于页码数(PageNumber)时,不显示省略号(...)
if (PageCount <= PageNumber)
{
for (int i = 1; i <= PageCount; i++)
GetPageNumberStr(i);
}
else
{
if (PageNumber % 2 != 0)
{
LeftPageNumberOne = (PageNumber / 2) + 1;
LeftPageNumberTwo = (PageNumber / 2);
RightPageNumber = (PageNumber / 2);
}
else
{
LeftPageNumberOne = (PageNumber / 2) + 1;
LeftPageNumberTwo = (PageNumber / 2);
RightPageNumber = (PageNumber / 2) - 1;
}
//总页数大于页码数(PageNumber)时(简单处理--算法)
if (NowPage > LeftPageNumberOne && NowPage < PageCount - RightPageNumber)
{
PagingControlInfo.Append("<span>...</span>");
for (int i = NowPage - LeftPageNumberTwo; i <= NowPage + RightPageNumber; i++)
GetPageNumberStr(i);
PagingControlInfo.Append("<span>...</span>");
}
else if (NowPage >= PageCount - RightPageNumber)
{
PagingControlInfo.Append("<span>...</span>");
for (int i = (PageCount - PageNumber) + 1; i <= PageCount; i++)
GetPageNumberStr(i);
}
else
{
for (int i = 1; i <= PageNumber; i++)
GetPageNumberStr(i);
PagingControlInfo.Append("<span>...</span>");
}
}
//下一页和末页
if (NowPage != PageCount)
{
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage=" + (NowPage + 1) + "\">下一页</a>");
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage=" + PageCount + "\">末页</a>");
}
}
#region //拼接页码方法
public void GetPageNumberStr(int i)
{
if (i == NowPage)
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage="+i+"\" style=\"border:0px;color:#ff5a00 ;\">" + i + "</a>");
else
PagingControlInfo.Append("<a href=\""+PageName+"?NowPage=" + i + "\">" + i + "</a>");
}
#endregion
#region //计算总页数
public int GetPageCount()
{
if (PageSize == 0)
PageSize = 20;//每页显示的记录条数为"0",则默认为"20"
if (Totalcount % PageSize == 0)
return (Totalcount / PageSize);
else
return (Totalcount / PageSize) + 1;
}
#endregion
#region //分页必须提供的基本属性
/// <summary>
/// 当前页
/// </summary>
public int NowPage { get; set; }
/// <summary>
/// 每页显示的记录条数
/// </summary>
public int PageSize { get; set; }
/// <summary>
/// 总条数
/// </summary>
public int Totalcount { get; set; }
/// <summary>
/// 页码(意思是前台分页控件显示的页数)
/// </summary>
public int PageNumber { get; set; }
/// <summary>
/// 当前页面名称如:"index.aspx"
/// </summary>
public string PageName { get;set;}
#endregion
#region //分页基本属性
/// <summary>
/// 左页码属性一
/// </summary>
public int LeftPageNumberOne { get; set; }
/// <summary>
/// 左页码属性二
/// </summary>
public int LeftPageNumberTwo { get; set; }
/// <summary>
/// 右页码
/// </summary>
public int RightPageNumber { get; set; }
#endregion
}
}
效果如下:自己给一下分页样式就Ok了。
分享到:
相关推荐
一个高效率的struts分页算法 遵循mvc开发的规范。便捷好维护
动态分页算法java代码
这个我人写的一个纯Java版的分页算法,与平台无关性,具有很好的通用性,同时附带完整的工程; 工程使用SQLServer2005,建表脚本在工程下的Setup中,根据你个人的数据库调整资源文件中的配置即可运行;同时这个算法...
海量数据库查询优化及分页算法方案,以“办公自动化”系统为例,探讨如何在有着1000万条数据的MS SQL Server数据库中实现快速的数据提取和数据分页。
海量 数据库 的查询 优化 及 分页 算法 方案
对oracle操作报表,能够对数据进行分裂分页算法
jsp分页技术算法,大家应该能接受这种算法,因为这个算法不难.希望大家好好研究吧
模拟仿真请求分页调度算法OPT、FIFO、LRU、LFU、CLOCK等模拟页面调度算法,并提供性能比较分析功能。用MFC界面实现
java分页算法
大数据 分页 算法
----------=====Java 分页算法 =====------------ 1.Struts+JDBC分页算法 1.1 创建分页控制类(如果使用kevinb.jar可以省略本步) --创建接口Pageable.java --创建实现类PageableResultSet.java 使用以这个实现类来...
非常通用的分页算法java实现,源代码仅供参考
分页算法中最全的,里面有分页的实例,又分页的sql语句,有分页的dll控件。绝对能满足你的分页要求。分页算法中最全的,里面有分页的实例,又分页的sql语句,有分页的dll控件。绝对能满足你的分页要求。
算法提取: 0.页码显示规则: 当前页为首页时不显示上一页; 上一页 1 2 3 … 20 下一页 当前页为尾页时不显示下一页; 上一页 1 … 17 18 19 20 下一页 1.页面总数(n) 显示全部页码:上一页 1 2 3 4 5 6 7 8...
mysql_海量数据库的查询优化及分页算法方案.doc
真分页、假分页、分页组件 1、 分页算法的用处 2、 分页算法的实现:真分页、加分页 3、 将分页代码形成组件 基于Mysql数据库以及Oracle数据库都有详细的讲解
Java分页算法以及一点CXF资料 Java分页算法以及一点Apache CXF webservice 资料
本系统实现分页存储的多种算法,包括最佳置换算法(OPT)(理想置换算法)、先进现出置换算法(FIFO、最近最久未使用(LRU)算法、简单Clock置换算法,可以灵活选择其中一种算法。
C++编写的请求分页储存管理的页置换算法模拟程序,模拟OPT,FIFO和LRU算法。可以输入序列也可以随机生成访问序列。可以输出整个调度的流程(表),缺页次数和缺页率。