做web开发一直用到分页控件,自己也动手实现了个,使用用户自定义控件。

翻页后数据加载使用委托,将具体实现放在在使用分页控件的页面进行注册。

有图有真相,给个直观的认识:

自定义分页控件前台代码:

<style type="text/css">
.pager-m-l {
margin-left: 10px;
} .pager {
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 14px;
color: #333;
background-color: #fff;
text-align: center;
border: 1px solid #eee;
border-radius: 5px;
height: 30px;
line-height: 30px;
margin: 10px auto;
width: 650px;
} .font-blue {
color: #5bc0de;
} .pager a {
color: #5bc0de;
text-decoration: none;
} .pager a.gray {
color: #808080;
} .pager-num {
width: 30px;
text-align: center;
} .pager-form-control {
color: #555;
background-color: #fff;
background-image: none;
border: 1px solid #ccc;
border-radius: 4px;
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
-webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
-o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
padding: 2px 0px;
margin: 0px 2px;
} .pager-form-control:focus {
border-color: #66afe9;
outline: 0;
-webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);
box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);
} .btn {
display: inline-block;
padding: 2px;
font-weight: normal;
text-align: center;
white-space: nowrap;
vertical-align: middle;
-ms-touch-action: manipulation;
touch-action: manipulation;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
background-image: none;
border: 1px solid transparent;
border-radius: 4px;
} .btn-default {
color: #333;
background-color: #fff;
border-color: #ccc;
}
</style>
<div class="pager">
<span>当前<asp:Label runat="server" ID="labCurrentPageIndex" CssClass="font-blue"></asp:Label>/<asp:Label runat="server" CssClass="font-blue" ID="labTotalNumberOfPages"></asp:Label>页</span>
<span class="pager-m-l">共<asp:Label runat="server" CssClass="font-blue" ID="labRecordCount"></asp:Label>条记录</span>
<span class="pager-m-l">
<asp:LinkButton runat="server" ID="labFirstPage" OnClick="labFirstPage_Click">首页</asp:LinkButton>
|
<asp:LinkButton runat="server" ID="labPreviousPage" OnClick="labPreviousPage_Click">上一页</asp:LinkButton>
|<asp:LinkButton runat="server" ID="labNextPage" OnClick="labNextPage_Click">下一页</asp:LinkButton>
|<asp:LinkButton runat="server" ID="labLastPage" OnClick="labLastPage_Click">尾页</asp:LinkButton>
</span>
<span class="pager-m-l">跳至<asp:TextBox runat="server" ID="txtPageNum" CssClass="pager-form-control pager-num">1</asp:TextBox>页
<asp:Button runat="server" Text="GO" ID="btnGo" CssClass="btn btn-default" OnClick="btnGo_Click" /></span>
<span class="pager-m-l">
<asp:DropDownList runat="server" ID="ddlPageSize" CssClass="pager-form-control" AutoPostBack="true" OnSelectedIndexChanged="ddlPageSize_SelectedIndexChanged">
<asp:ListItem Text="10" Value="10"></asp:ListItem>
<asp:ListItem Text="20" Value="20"></asp:ListItem>
<asp:ListItem Text="30" Value="30"></asp:ListItem>
<asp:ListItem Text="50" Value="50"></asp:ListItem>
<asp:ListItem Text="100" Value="100"></asp:ListItem>
</asp:DropDownList>条/每页</span>
</div>

自定义分页控件后台代码:

private const string viewStateCurrentPageIndex = "CurrentPageIndex";
private const string viewStateRecordCount = "RecordCount"; public delegate void PageChangedHandle();
public event PageChangedHandle OnPageChanged; public int PageSize
{
get
{
return Convert.ToInt32(ddlPageSize.SelectedValue);
}
} public int CurrentPageIndex
{
set
{
ViewState[viewStateCurrentPageIndex] = value;
}
get
{
if (ViewState[viewStateCurrentPageIndex] == null)
{
ViewState[viewStateCurrentPageIndex] = ;
} return Convert.ToInt32(ViewState[viewStateCurrentPageIndex]);
}
}
public int RecordCount
{
get
{
if (ViewState[viewStateRecordCount] == null)
{
ViewState[viewStateRecordCount] = ;
} return Convert.ToInt32(ViewState[viewStateRecordCount]);
}
set
{
ViewState[viewStateRecordCount] = value;
}
}
private int TotalNumberOfPages
{
get
{
return RecordCount % PageSize == ? RecordCount / PageSize : (RecordCount / PageSize) + ;
}
} protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{ }
} protected void labFirstPage_Click(object sender, EventArgs e)
{
CurrentPageIndex = ; this.DataBind();
} protected void labPreviousPage_Click(object sender, EventArgs e)
{
CurrentPageIndex -= ; this.DataBind();
} protected void labNextPage_Click(object sender, EventArgs e)
{
CurrentPageIndex += ; this.DataBind();
} protected void labLastPage_Click(object sender, EventArgs e)
{
CurrentPageIndex = TotalNumberOfPages; this.DataBind();
} protected void btnGo_Click(object sender, EventArgs e)
{
int pageNum = ;
bool isNum = Int32.TryParse(txtPageNum.Text, out pageNum);
if (isNum)
{
CurrentPageIndex = Math.Min(pageNum, TotalNumberOfPages);
} this.DataBind();
} protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
{
CurrentPageIndex = ; this.DataBind();
} protected override void DataBind(bool raiseOnDataBinding)
{
BindPager();
base.DataBind(raiseOnDataBinding); if (OnPageChanged != null)
{
OnPageChanged();
}
} private void BindPager()
{
labCurrentPageIndex.Text = CurrentPageIndex.ToString();
labTotalNumberOfPages.Text = TotalNumberOfPages.ToString();
labRecordCount.Text = RecordCount.ToString(); SetNavigateEnabled();
} private void SetNavigateEnabled()
{
txtPageNum.Text = CurrentPageIndex.ToString();
labFirstPage.Enabled = true;
labPreviousPage.Enabled = true;
labNextPage.Enabled = true;
labLastPage.Enabled = true; labFirstPage.CssClass = "font-blue";
labPreviousPage.CssClass = "font-blue";
labNextPage.CssClass = "font-blue";
labLastPage.CssClass = "font-blue"; if (CurrentPageIndex == )
{
labFirstPage.Enabled = false;
labPreviousPage.Enabled = false; labFirstPage.CssClass = "gray";
labPreviousPage.CssClass = "gray";
}
if (CurrentPageIndex == TotalNumberOfPages)
{
labNextPage.Enabled = false;
labLastPage.Enabled = false; labNextPage.CssClass = "gray";
labLastPage.CssClass = "gray";
}
if (RecordCount == )
{
labFirstPage.Enabled = false;
labPreviousPage.Enabled = false; labFirstPage.CssClass = "gray";
labPreviousPage.CssClass = "gray"; labNextPage.Enabled = false;
labLastPage.Enabled = false; labNextPage.CssClass = "gray";
labLastPage.CssClass = "gray";
}
}

当前页码、总共多少条记录使用ViewState记录状态信息,因为导航控件会引起回发刷新。
分页后的数据加载,使用事件。

事件的具体实现放在使用分页控件的具体页面中,进行事件的注册。

测试分页控件的前台页面:

<div style="margin-bottom:10px;">
text:
<asp:TextBox ID="txtContent" runat="server"></asp:TextBox>
<asp:Button ID="btnQuery" runat="server" Text="查 询" OnClick="btnQuery_Click"/>
</div>
<div>
<asp:GridView ID="gvList" runat="server" Width="99%" AutoGenerateColumns="true"></asp:GridView>
<uc1:PagerControl runat="server" ID="Pager" />
</div>

测试分页控件的后台代码:

 private const string dtSourceViewStateKey = "dtSourceViewStateKey";

        protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
BindData(true); }
Pager.OnPageChanged += OnPageChanged;
} private void BindData(bool bindRecordCount)
{
DataTable dtSource = GetDataSource(); var source = dtSource.AsEnumerable();
if (!string.IsNullOrEmpty(txtContent.Text.Trim()))
{
source = source.Where(w => w.Field<string>("text").Contains(txtContent.Text.Trim()));
} if (bindRecordCount)
{
Pager.RecordCount = source.Count();
Pager.CurrentPageIndex = ;
Pager.DataBind();
} gvList.DataSource = source
.Skip((Pager.CurrentPageIndex - ) * Pager.PageSize)
.Take(Pager.PageSize)
.Select(r => new { id = r["id"].ToString(), text = r["text"].ToString() })
.ToList();
gvList.DataBind();
} private void OnPageChanged()
{
BindData(false);
} private DataTable InitDataTable()
{
DataTable dtSource = new DataTable();
DataColumn id = new DataColumn("id");
id.AutoIncrement = true;
id.AutoIncrementSeed = ; dtSource.Columns.Add(id);
dtSource.Columns.Add("text"); for (int i = ; i <= ; i++)
{
DataRow dr = dtSource.NewRow();
dr["text"] = "内容" + i; dtSource.Rows.Add(dr);
} return dtSource;
} private DataTable GetDataSource()
{
if (ViewState[dtSourceViewStateKey] == null)
{
ViewState[dtSourceViewStateKey] = InitDataTable();
} return ViewState[dtSourceViewStateKey] as DataTable;
} protected void btnQuery_Click(object sender, EventArgs e)
{
BindData(true);
}

在Page_Load中注册翻页后的事件。

asp.net webform 自定义分页控件的更多相关文章

  1. C# DataGridView自定义分页控件

    好些日子不仔细写C#代码了,现在主要是Java项目,C#.Net相关项目不多了,有点手生了,以下代码不足之处望各位提出建议和批评. 近日闲来无事想研究一下自定义控件,虽然之前也看过,那也仅限于皮毛,粗 ...

  2. Mvc自定义分页控件

    MVC开发分页常常使用第三方控件,生成的分页HTML带有版权申明,虽然免费,但是总有的别扭.于是,某日,楼主闲来蛋疼,折腾了个自定义分页控件: 先来展示下效果图: 1>当分页不超过10页的时候, ...

  3. WPF自定义分页控件,样式自定义,简单易用

    WPF自定义分页控件 做了许久伸手党,终于有机会贡献一波,搜索一下WPF分页控件,还是多,但是不太通用,主要就是样式问题,这个WPF很好解决,还有一个就是分页控件嘛,只关心几个数字的变动就行了,把页码 ...

  4. asp.net中自定义验证控件

    在windows2003中,可能iis版本太底,不支持TextBox的类型设为Number类型,所以会报错,所以去掉后直接用验证控件来控制必须输入数字好了. <asp:RegularExpres ...

  5. Winform自定义分页控件的实现

    实现效果 有点丑陋 但是功能是没问题的 测试过 实现思路 先创建一个用户控件 代码实现 public partial class PagerControl : UserControl { ; /// ...

  6. winform 自定义分页控件 及DataGridview数据绑定

    分页效果如上图所示,用到的控件均为基本控件 ,其方法如下 右击项目-添加-新建项 选择用户控件 然后在用户控件中拖入所需要的Label,Button,Text 用户控件全部代码: using Syst ...

  7. WPF管理系统自定义分页控件 - WPF特工队内部资料

    最近做一个演示的管理系统项目,需要用到分页控件,在网上找了很多,依然找到与UI模版匹配的,最后干脆自己写一个. 分页控件分析: 1.分页控件分简单显示和复杂显示两种: 2.包含上一页.下一页以及页码明 ...

  8. WPF 自定义分页控件二

    一:添加自定义分页控件,命名为KDataPagerTwo: public class KDataPagerTwo : Control, INotifyPropertyChanged { static ...

  9. 自定义分页控件-基于Zhifeiya的分页控件改版

    基于Zhifeiya的分页控件改版的分页. html显示代码: <div class="pagelist"> {{.pagerHtml}} </div> c ...

随机推荐

  1. spring源码分析之freemarker整合

    FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它不是面向最终用户的,而是一个Java类库,是一款程 ...

  2. Java 经典入门(一)

    一.什么是 Java 技术?为何需要 Java? Java 是由 Sun Microsystems 在 1995 年首先发布的编程语言和计算平台.有许多应用程序和 Web 站点只有在安装 Java 后 ...

  3. 关于DDD的学习资料汇总

    DDD(Domain-Driven Design)领域驱动设计,第一次看到DDD是在学习ABP时,在其中的介绍中看到的.what,DDD是个什么鬼,我不是小白,是大白,没听过.于是乎,度娘查查查,找到 ...

  4. Lind.DDD.LindMQ~关于持久化到Redis的消息格式

    回到目录 关于持久化到Redis的消息格式,主要是说在Broker上把消息持久化的过程中,需要存储哪些类型的消息,因为我们的消息是分topic的,而每个topic又有若干个queue组成,而我们的to ...

  5. BPM SharePoint解决方案分享

    一.需求分析 SharePoint作为微软推出的协同类平台产品,为客户提供了门户.内容.文档.流程.社区.搜索.BI等一系列的解决方案,然而其流程功能由于设计理念差异,不能完全满足客户的需求,主要原因 ...

  6. 【从零开始学BPM,Day1】工作流管理平台架构学习

    [课程主题] 主题:5天,一起从零开始学习BPM [课程形式] 1.为期5天的短任务学习 2.每天观看一个视频,视频学习时间自由安排. [第一天课程] Step 1 软件下载:H3 BPM10.0全开 ...

  7. mysql删除重复记录语句的方法

    例如: id name value 1 a pp 2 a pp 3 b iii 4 b pp 5 b pp 6 c pp 7 c pp 8 c iii id是主键 要求得到这样的结果 id name ...

  8. 烂泥:数据库管理之phpmyadmin免密码配置

    本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb 其实这篇文章很早就想写了,但是一直没有时间.刚好今天下午稍微空了点,就把这篇文章整理出来 ...

  9. Tomcat之APR错误

    在发布Apache Tomcat的时候,突然出现如下错误: An incompatible version 1.1.31 of the APR based Apache Tomcat Native l ...

  10. 不该活着的SqlHelper和DBHelper

    前言: 还记得刚学ADO.NET的情景么? 还记得当年是怎么从ADO.NET被忽悠到用SqlHelper的么? 话说从入门到走上工作岗位那些年,我们就一直被纯纯地教导或引导,ADO.NET太原始,得封 ...