ASP.Net 分页控件源码

特性:
、支持datagrid,datalist等分种数据显示控件,理论上只要有datasource的控件都可以
、支持url方式分页,url分页的每一页都可以被搜索引擎搜到,并且支持url重写
、控件样式可自定义
、封装完全,使用过程序只需写一行代码


代码如下:

/******************************************************************
** 文件名:Pager.cs
** 创建人:杨响武
** 日 期:2005年7月27日
** 修改人:
** 日 期:
** 描 述:
**
**----------------------------------------------------------------
******************************************************************/

using System;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Web;
using System.Web.UI;
using System.Text.RegularExpressions;

namespace MyCompany.Controls
{
/// <summary>
/// 分页控件
/// </summary>
public class Pager : Label, INamingContainer
{
#region 成员变量和构造函数
HttpContext context = HttpContext.Current;
Label countLabel;
HyperLink previousButton;
HyperLink nextButton;
HyperLink firstButton;
HyperLink lastButton;
HyperLink[] pagingLinkButtons;

public override ControlCollection Controls
{
get
{
EnsureChildControls();
return base.Controls;
}
}

protected override void CreateChildControls()
{
Controls.Clear();

AddCountLabel();

AddPageButtons();

AddPreviousNextHyperLinks();

AddFirstLastHyperLinks();
}
#endregion

#region 呈现方法
protected override void Render(HtmlTextWriter writer)
{
// 修改总页数小于等于1的时候不呈现任何控件
// int totalPages = CalculateTotalPages();
//
// if (totalPages <= 1)
// return;

AddAttributesToRender(writer);

writer.AddAttribute(HtmlTextWriterAttribute.Class, this.CssClass, false);

RenderCountLabel(writer);

RenderFirst(writer);

RenderPrevious(writer);

RenderPagingButtons(writer);

RenderNext(writer);

RenderLast(writer);
}

void RenderCountLabel(HtmlTextWriter writer)
{
countLabel.RenderControl(writer);

LiteralControl l = new LiteralControl(" ");
l.RenderControl(writer);
}

void RenderFirst (HtmlTextWriter writer)
{
firstButton.RenderControl(writer);

LiteralControl l = new LiteralControl(" ");
l.RenderControl(writer);
}

void RenderLast (HtmlTextWriter writer)
{
lastButton.RenderControl(writer);

LiteralControl l = new LiteralControl(" ");
l.RenderControl(writer);
}

void RenderPrevious (HtmlTextWriter writer)
{
previousButton.RenderControl(writer);

LiteralControl l = new LiteralControl(" ");
l.RenderControl(writer);
}

void RenderNext(HtmlTextWriter writer)
{
nextButton.RenderControl(writer);

LiteralControl l = new LiteralControl(" ");
l.RenderControl(writer);
}

private void RenderButtonRange(int start, int end, HtmlTextWriter writer)
{
for (int i = start; i < end; i++)
{
if (PageIndex == i)
{
Literal l = new Literal();
l.Text = "<font color =red>" + (i + 1).ToString() + "</font>";

l.RenderControl(writer);
}
else
{
pagingLinkButtons.RenderControl(writer);
}
if (i < (end - 1))
writer.Write(" ");
}

LiteralControl l1 = new LiteralControl(" ");
l1.RenderControl(writer);
}

private void RenderPagingButtons(HtmlTextWriter writer)
{
int totalPages;

totalPages = CalculateTotalPages();

if (totalPages <= 10)
{
RenderButtonRange(0, totalPages, writer);
}
else
{
int lowerBound = (PageIndex - 4);
int upperBount = (PageIndex + 6);

if (lowerBound <= 0)
lowerBound = 0;

if (PageIndex <= 4)
RenderButtonRange(0, 10, writer);

else if (PageIndex < (totalPages - 5))
RenderButtonRange(lowerBound, (PageIndex + 6), writer);

else if (PageIndex >= (totalPages - 5))
RenderButtonRange((totalPages - 10), totalPages, writer);
}
}

#endregion

#region 控件树方法
/// <summary>
/// 信息标签
/// </summary>
void AddCountLabel()
{
countLabel = new Label();
countLabel.ID = "countLabel";
countLabel.Text = string.Format(text, CalculateTotalPages().ToString("n0"));

Controls.Add(countLabel);
}

private void AddPageButtons()
{
pagingLinkButtons = new HyperLink[CalculateTotalPages()];

for (int i = 0; i < pagingLinkButtons.Length; i++)
{
pagingLinkButtons = new HyperLink();
pagingLinkButtons.EnableViewState = false;
pagingLinkButtons.Text = (i + 1).ToString();
pagingLinkButtons.ID = i.ToString();
pagingLinkButtons.CssClass = linkCss;
pagingLinkButtons.NavigateUrl = GetHrefString(i);

Controls.Add(pagingLinkButtons);
}
}

/// <summary>
/// 首页末页
/// </summary>
void AddFirstLastHyperLinks()
{
firstButton = new HyperLink();
firstButton.ID = "First";
firstButton.Text = "首页";
if(PageIndex != 0 && CalculateTotalPages() > 0)
{
firstButton.NavigateUrl = GetHrefString(0);
}
else
{
firstButton.Enabled = false;
}

Controls.Add(firstButton);

lastButton = new HyperLink();
lastButton.ID = "Last";
lastButton.Text = "末页";
if(PageIndex != CalculateTotalPages() - 1)
{
lastButton.NavigateUrl = GetHrefString(CalculateTotalPages() - 1);
}
else
{
lastButton.Enabled = false;
}
Controls.Add(lastButton);
}

/// <summary>
/// 上一页下一页
/// </summary>
void AddPreviousNextHyperLinks()
{
previousButton = new HyperLink();
previousButton.ID = "Prev";
previousButton.Text = "上一页";
if (HasPrevious)
{
previousButton.NavigateUrl = GetHrefString(PageIndex - 1);
}
else
{
previousButton.Enabled = false;
}
Controls.Add(previousButton);

nextButton = new HyperLink();
nextButton.ID = "Next";
nextButton.Text = "下一页";
if(HasNext)
{
nextButton.NavigateUrl = GetHrefString(PageIndex + 1);
}
else
{
nextButton.Enabled = false;
}
Controls.Add(nextButton);
}
#endregion

#region 私有属性
private bool HasPrevious
{
get
{
if (PageIndex > 0)
return true;

return false;
}
}

private bool HasNext
{
get
{
if (PageIndex + 1 < CalculateTotalPages() )
return true;

return false;
}
}
#endregion

#region 帮助方法和公共属性

/// <summary>
/// 获取分页导航按钮的超链接字符串
/// </summary>
/// <param name="pageIndex">该分页按钮相对应的页索引</param>
/// <returns>分页导航按钮的超链接字符串</returns>
private string GetHrefString(int pageIndex)
{
string url = Page.Request.RawUrl;

if (Regex.IsMatch(url, @"(\d+).shtml", RegexOptions.IgnoreCase))
{
url = Regex.Replace(url, @"(\d+).shtml", pageIndex + ".shtml");
}

if (Regex.IsMatch(url, @"PageIndex=(\d+)", RegexOptions.IgnoreCase))
{
url = Regex.Replace(url, @"PageIndex=(\d+)", "PageIndex=" + pageIndex.ToString());
}

return Page.Server.UrlPathEncode(url);
}

public int CalculateTotalPages()
{
int totalPagesAvailable;

if (TotalRecords == 0)
return 0;

totalPagesAvailable = TotalRecords / PageSize;

if ((TotalRecords % PageSize) > 0)
totalPagesAvailable++;

return totalPagesAvailable;
}

/// <summary>
/// 当前页
/// </summary>
public int PageIndex
{
get
{
int _pageIndex = 0;

if ((!Page.IsPostBack) && (context.PageIndex > 0))
_pageIndex = context.PageIndex;
else
_pageIndex = Convert.ToInt32(ViewState["PageIndex"]);

if (_pageIndex < 0)
return 0;
else
{
if (_pageIndex > CalculateTotalPages()-1)
return CalculateTotalPages()-1;
else
return _pageIndex;
}
}
set
{
ViewState["PageIndex"] = value;
}
}

/// <summary>
/// 每页记录数
/// </summary>
public int PageSize
{
get
{
int pageSize = Convert.ToInt32(ViewState["PageSize"]);

if (pageSize == 0)
{
return 10;
}

return pageSize;
}
set
{
ViewState["PageSize"] = value;
}

}

/// <summary>
/// 总记录数
/// </summary>
public int TotalRecords
{
get
{
return Convert.ToInt32(ViewState["TotalRecords"]);
}
set
{
ViewState["TotalRecords"] = value;
}
}

private string text = "共{0}页";

private string linkCss = "";
/// <summary>
/// 链接样式
/// </summary>
public string LinkCss
{
get { return linkCss; }
set { linkCss = value;}
}

private string textCss = "";
/// <summary>
/// 文字样式
/// </summary>
public string TextCss
{
get { return textCss; }
set { textCss = value;}
}

public string TextFormat
{
get
{
return text;
}
set
{
text = value;
}
}

#endregion
}
}

在页面上只需要向下面这样写:


代码如下:

<%@ Control Language="c#" %>
<%@ Register TagPrefix="Anchor" Namespace="MyCompany.Controls" Assembly="MyCompany.Controls" %>
<ANCHOR:PAGER id="Pager1" runat="server"></ANCHOR:PAGER>

(0)

相关推荐

  • asp.net自定义分页控件示例

    一..ascx页面 复制代码 代码如下: <%@ Control Language="C#" AutoEventWireup="true" CodeBehind="Pagination.ascx.cs" Inherits="IOCS.WEB.UserControl.Pagination" %><link href="../Content/Css/Pager.css" rel="s

  • 关于asp.net 自定义分页控件

    这几天空学习了下自定义控件,参考了aspnetpager开发了自己的分页控件.相对aspnetpager来说功能是多,但个人感觉他的代码太多. 界面: 使用: <%@ Register assembly="YSM.AspNetPager" namespace="YSM.AspNetPager" tagprefix="cc1" %> 页面注册控件,也可以在web.config中配置 1.ajax之UpdatePanel分页则把控件放到U

  • asp.net下Repeater使用 AspNetPager分页控件

    一.AspNetPager分页控件 分页是Web应用程序中最常用到的功能之一,在ASP.NET中,虽然自带了一个可以分页的DataGrid(asp.net 1.1)和GridView(asp.net 2.0)控件,但其分页功能并不尽如人意,如可定制性差.无法通过Url实现分页功能等,而且有时候我们需要对DataList和Repeater甚至自定义数据绑定控件进行分页,手工编写分页代码不但技术难度大.任务繁琐而且代码重用率极低,因此分页已成为许多ASP.NET程序员最头疼的问题之一. AspNet

  • asp.net中使用自定义控件的方式实现一个分页控件的代码

    一.概述 在web开发中,常常需要显示一些数据,而为了方便排版及浏览,我们只需要显示所有记录中的一部分.一般情况下,我们采用分页来实现这个需求.实现分页的方法多种多样,在本文中,我们采用了一个分页空间来记录记录总数.当前页.总页数及页面大小等.为了有一个直观上的印象,先展示该控件运行后的效果,效果如下图所示: 二.实现方案 为了实现该效果图,在asp.net中,可以使用Custom Controls and User Controls两种方式,User Controls的实现方式及其简单,而且使

  • AspNetAjaxPager,Asp.Net通用无刷新Ajax分页控件,支持多样式多数据绑定

    本控件可以对GridView,Repeater,DataGrid,DataList...几乎所有的.net数据绑定控件进行分页,全部无刷新,数据绑定部分可以使用存储过程也可以直接使用sql语句,这对本控件没有任何干扰!本控件具有较好的用户界面,能够根据需要变换各种样式,配合css控制效果则更好! 1.分页样式效果图: 2.如何使用: 于bin目录下添加:AspNetAjaxPager.dll引用 aspx文件内容: 复制代码 代码如下: <%@ Page Language="C#"

  • 解析asp.net的分页控件

    一.说明 AspNetPager.dll这个分页控件主要用于asp.net webform网站,现将整理代码如下 二.代码 1.首先在测试页面Default.aspx页面添加引用 <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix="webdiyer" %> 2.写一个Repeater列表控件用于显示数据 <asp:Repeater ID

  • asp.net webform自定义分页控件

    做web开发一直用到分页控件,自己也动手实现了个,使用用户自定义控件. 翻页后数据加载使用委托,将具体实现放在在使用分页控件的页面进行注册. 有图有真相,给个直观的认识: 自定义分页控件前台代码: <style type="text/css"> .pager-m-l { margin-left: 10px; } .pager { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; fo

  • asp.net分页控件AspNetPager的样式美化

    在前段时间的开发网站的过程中,突然觉得这个简洁的样式看着和网站整体的风格实在不搭调,于是看看AspNetPager的最后生成html,写了一段CSS样式,将分页的样式和网站整体风格统一起来了. 效果如下: 做的不是很好看,希望大家不要丢砖头,俺的头没包棉絮,伤不起 ~-_-~ CSS样式表: /* AspNetPager Style Power By http://www.edweb.cn */.pager{ width:95%;  margin:10px; line-height:20px;

  • 分享一个asp.net pager分页控件

    效果: js: 复制代码 代码如下: $.fn.extend({ JPager: function (cfg, pageIndex, pageSize) { if (cfg && pageIndex > 0 && pageSize>0) { var token = "#" + this.attr("id"); this.empty(); var pageFirst = function () { $(token).JPag

  • asp.net分页控件使用详解【附实例下载】

    一.说明 AspNetPager.dll这个分页控件主要用于asp.net webform网站,现将整理代码如下 二.代码 1.首先在测试页面Default.aspx页面添加引用 <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix="webdiyer" %> 2.写一个Repeater列表控件用于显示数据 <asp:Repeater ID

随机推荐