asp.net 分页-自己写分页控件
去年就发表过asp.net 分页-利用后台直接生成html分页 ,那种方法只是单纯的实现了分页,基本不能使用,那时就想写个自己的分页控件,无奈能力有限。最近有点时间了,就自己做出了这个分页控件。我承认,这个控件参考了别人的,但是其实里面的原理都相同,差异只是展现方式而已。
去年就在做一个自己的后台系统,刚开始用的asp.net,做了一部分就没有做了,因为缺少权限控制类别。后面转为用asp.net mvc4做,也只是做了一部分,觉得不太方便,也许是我不太会用。再用ajax+ashx做了一部分,虽然体验不错,但是我还是放弃了,比起纯正的asp.net还是麻烦多了。我要做的系统不是很大,觉得用asp.net很方便,权限控制,通用控件可以加快步伐。所以我决定先做出来再说,怎么简单怎么做。
展示效果
属性解释:
Css:定义div和链接等的样式
SelectCss:当前选择的链接样式
CssEnable:本来想做一个默认的样式,但是感觉需要不大,所以这个属性暂时无用
PageSize:每页显示的数据条数
PreNextVisable:上一页和下一页的显示,默认为显示
TotalVisable:显示总数,默认为不显示,图上显示错误:共{0}笔
运行效果:
实现过程
//****************************************************************************************
//作者:轻狂书生
//博客地址:http://www.cnblogs.com/xiaoshuai1992
//create: 2014/5/5
//功能:分页控件的实现
//使用方法:正常控件使用方法
//***************************************************************************************** using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.ComponentModel;
[assembly: TagPrefix("XS.Framework.Control", "xs")]
namespace pageControl
{
public class PageChangedEventArgs : EventArgs
{
int ITotalCount = ;
int ICurrentPage = ;
int IPageSize = ;
public int ECurrentPage
{
get { return ICurrentPage; }
set { ICurrentPage = value; }
}
public int ETotalCount
{
get { return ITotalCount; }
set { ITotalCount = value; }
}
public int EPageSize
{
get { return IPageSize; }
set { IPageSize = value; }
}
public PageChangedEventArgs(int curPage, int totalcount, int pageSize)
{
ECurrentPage = curPage;
ETotalCount = totalcount;
EPageSize = pageSize;
}
}
public delegate void PageChangedEvent(object sender, PageChangedEventArgs e);
public class xsPageControl : Control, IPostBackEventHandler
{
#region 属性
string _preText = "上一页";
string _nextText = "下一页";
string _totalText = "共{0}笔";
bool _totalVisable = false;//由于存在尾页号,总页数不是必须,故这里我设置默认为不打开
bool _preNextVisable = true;
int _pageSize = ;
string _css = "xsPage";
string _selectCss = "xsSelect";
bool _cssEnable = true;
int ITotalCount = ;
int ICurrentPage = ; [Category("Text")]
public string PreText
{
get { return _preText; }
set { _preText = value; }
}
[Category("Text")]
public string NextText
{
get { return _nextText; }
set { _nextText = value; }
}
[Category("Text")]
public string TotalText
{
get { return _totalText; }
set { _totalText = value; }
}
[Category("Text")]
public bool TotalVisable
{
get { return _totalVisable; }
set { _totalVisable = value; }
}
[Category("Text")]
public bool PreNextVisable
{
get { return _preNextVisable; }
set { _preNextVisable = value; }
} [Category("Size")]
public int PageSize
{
get { return _pageSize; }
set { _pageSize = value; }
}
[Category("CSS")]
public string Css
{
get { return _css; }
set { _css = value; }
}
[Category("CSS")]
public string SelectCss
{
get { return _selectCss; }
set { _selectCss = value; }
}
[Category("CSS")]
/// <summary>
/// 是否使用默认CSS,自定义CSS无效
/// </summary>
public bool CssEnable
{
get { return _cssEnable; }
set { _cssEnable = value; }
}
[Browsable(false)]
public int CurrentPage
{
set { ICurrentPage = value; }
}
[Browsable(false)]
public int TotalPage
{
get
{
int tpage = ;
if (PageSize > )
{
tpage = (TotalCount % PageSize == ? TotalCount / PageSize : TotalCount / PageSize + );
}
return tpage; }
}
[Browsable(false)]
public int TotalCount
{
get { return ITotalCount; }
set { ITotalCount = value; }
}
#endregion public event PageChangedEvent PageChanged; #region 效果呈现
public override void RenderControl(HtmlTextWriter writer)
{
Render(writer);
} protected override void Render(HtmlTextWriter writer)
{
if (DesignMode)
{
writer.AddAttribute(HtmlTextWriterAttribute.Id, this.ClientID);
writer.AddAttribute(HtmlTextWriterAttribute.Name, this.UniqueID);
writer.AddAttribute(HtmlTextWriterAttribute.Class, Css);
writer.RenderBeginTag(HtmlTextWriterTag.Div); if (TotalVisable)
{
writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write(string.Format(TotalText, ));
writer.RenderEndTag();
writer.Write(" ");
}
if (PreNextVisable)
{
writer.AddAttribute(HtmlTextWriterAttribute.Href, "#");
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(PreText);
writer.RenderEndTag();
writer.Write(" ");
}
for (int i = ; i <= ; i++)
{
writer.AddAttribute(HtmlTextWriterAttribute.Href, "#");
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(i.ToString());
writer.RenderEndTag();
writer.Write(" ");
}
if (PreNextVisable)
{
writer.AddAttribute(HtmlTextWriterAttribute.Href, "#");
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(NextText);
writer.RenderEndTag();
writer.Write(" ");
}
writer.RenderEndTag();
}
else
{
writer.AddAttribute(HtmlTextWriterAttribute.Id, this.ClientID);
writer.AddAttribute(HtmlTextWriterAttribute.Name, this.UniqueID);
writer.AddAttribute(HtmlTextWriterAttribute.Class, Css);
writer.RenderBeginTag(HtmlTextWriterTag.Div); if (TotalVisable)
{
writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write(string.Format(TotalText, ITotalCount));
writer.RenderEndTag();
}
if (PreNextVisable && ICurrentPage != )
{
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, ICurrentPage - + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(PreText);
writer.RenderEndTag();
}
if (TotalPage <= )
{
for (int i = ; i <= TotalPage; i++)
{
if (i == ICurrentPage)
{
//添加当前选择的样式
writer.AddAttribute(HtmlTextWriterAttribute.Class, SelectCss);
}
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, i + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(i.ToString());
writer.RenderEndTag();
}
}
else
{
if (ICurrentPage - > && ICurrentPage + < TotalPage)//前后都有的
{
//添加第一页
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write("");
writer.RenderEndTag(); writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write("…");
writer.RenderEndTag(); for (int i = ICurrentPage - ; i <= ICurrentPage + ; i++)
{
if (i == ICurrentPage)
{
//添加当前选择的样式
writer.AddAttribute(HtmlTextWriterAttribute.Class, SelectCss);
}
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, i + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(i.ToString());
writer.RenderEndTag();
}
//添加最后一页
writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write("…");
writer.RenderEndTag();
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, TotalPage + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(TotalPage.ToString());
writer.RenderEndTag();
}
else if (ICurrentPage - <= )//前面不够,后面有多余
{
for (int i = ; i <= ; i++)
{
if (i == ICurrentPage)
{
//添加当前选择的样式
writer.AddAttribute(HtmlTextWriterAttribute.Class, SelectCss);
}
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, i + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(i.ToString());
writer.RenderEndTag();
}
//添加最后一页
writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write("…");
writer.RenderEndTag();
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, TotalPage + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(TotalPage.ToString());
writer.RenderEndTag(); }
else if (ICurrentPage + >= TotalPage)//前面多余,后面不足
{
//添加第一页
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write("");
writer.RenderEndTag();
writer.RenderBeginTag(HtmlTextWriterTag.Span);
writer.Write("…");
writer.RenderEndTag();
for (int i = TotalPage - ; i <= TotalPage; i++)
{
if (i == ICurrentPage)
{
//添加当前选择的样式
writer.AddAttribute(HtmlTextWriterAttribute.Class, SelectCss);
}
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, i + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(i.ToString());
writer.RenderEndTag();
}
} }
if (PreNextVisable && ICurrentPage != TotalPage && TotalPage > )
{
writer.AddAttribute(HtmlTextWriterAttribute.Href, "javascript:" + Page.ClientScript.GetPostBackEventReference(this, ICurrentPage + + ""));
writer.RenderBeginTag(HtmlTextWriterTag.A);
writer.Write(NextText);
writer.RenderEndTag();
}
writer.RenderEndTag();
}
} #endregion /// <summary>
/// 设置翻页
/// </summary>
/// <param name="gotoPage"></param>
protected virtual void OnPageChanged(int gotoPage)
{
PageChangedEventArgs e = new PageChangedEventArgs(gotoPage, TotalCount, PageSize);
if (this.PageChanged != null)
{
PageChanged(this, e);
CurrentPage = e.ECurrentPage;
TotalCount = e.ETotalCount;
PageSize = e.EPageSize;
}
}
public void RaisePostBackEvent(string eventArgument)
{
int gotopage = Convert.ToInt32(eventArgument);
OnPageChanged(gotopage);
} /// <summary>
/// 第一次进入页面需要显示调用
/// </summary>
public void StartShowPage()
{
OnPageChanged();
}
/// <summary>
/// 删除或更新后可以直接刷新
/// </summary>
public void RefreshPage()
{
OnPageChanged(ICurrentPage);
}
}
}
重要代码解释,其他可以看注释
1:控件继承自Control, IPostBackEventHandler
链接调用的为Page.ClientScript.GetPostBackEventReference()方法,点击时进入RaisePostBackEvent 方法
RaisePostBackEvent 方法实现接口IPostBackEventHandler,在进入页面时进入调用OnPageChanged()方法实现分页
2:PageChangedEventArgs 类
定义为PageChanged的参数,可以把当前的页数,总数,每页显示数带到页面进行查询,也可以在页面设置这些属性,实现控件的显示
页面使用
拖入控件,设置好属性,把要实现的数据查询和绑定写在pagechanged里面,参数里面包含了分页的参数(当前页数,每页显示数)
protected void xsPageControl1_PageChanged(object sender, PageChangedEventArgs e)
{
}
进入页面地方使用
xsPageControl1.StartShowPage();
页面数据修改或删除后刷新当页
xsPageControl1.RefreshPage();
源码下载
以后还会对其进行修改和完善,也可以写一下类别配合其使用,这个控件没有与其他控件关联,也没用和数据库关联,可以自行对任意需要分页显示的控件进行分页。
20140508修改
几天的测试发现了里面的bug
当前页面的刷新会找不到当前的页数,是因为页面刷新后控件类重新生成,当前页面的值也就回到了原点。
所以我考虑把CurrentPage 这个属性变为用页面缓存进行保存,经测试成功
public int CurrentPage
{
get { return Convert.ToInt32(ViewState[UniqueID + "xsCurrentPage"] == null ? : ViewState[UniqueID + "xsCurrentPage"]); }
set { ViewState[UniqueID + "xsCurrentPage"] = value; }
}
20140509修改
昨天发现了一个bug,如果数据有6条,每页显示5条。我这时选到第二页,删除第6条,调用RefreshPage()是当前页面记录的2,可是由于删除其实没有第二页了。
解决办法是在OnPageChanged 发生后判断总页数和当前页,如果当前页大于总页数,执行OnPageChanged(总页数)。这样可以解决,可是得查询2遍了
asp.net 分页-自己写分页控件的更多相关文章
- asp.net 弹出式日历控件 选择日期 Calendar控件
原文地址:asp.net 弹出式日历控件 选择日期 Calendar控件 作者:逸苡 html代码: <%@ Page Language="C#" CodeFile=&quo ...
- jQuery Validate 验证,校验规则写在控件中的具体例子
将校验规则写到控件中 <script src="../js/jquery.js" type="text/javascript"></scrip ...
- 自写JQ控件-树状菜单控件[demo下载]
一个多月没有写博客了,最近也弄一个基于JQ的树状菜单控件,在此分享给大家.另外呢,通过这个例子分享一下怎么写JQ控件的. 事实上工作中,也是经常遇到的,有些时候自己想实现一些前端效果,用网上一些插件吧 ...
- ASP.NET MVC 中使用用户控件——转
讲讲怎么在 ASP.NET MVC2中使用用户控件.首先我们新建一个用户控件, 我们命名为SelectGroup.ascx,代码如下 <%@ Control Language="C ...
- ASP.NET的面包屑导航控件、树形导航控件、菜单控件
原文:http://blog.csdn.net/pan_junbiao/article/details/8579293 ASP.NET的面包屑导航控件.树形导航控件.菜单控件. 1. 面包屑导航控件— ...
- 分页技术之GridView控件
GridView控件实现分页技术 第一步:设置GridView控件的属性,跟分页相关的属性设置如下: AllowPaging="true":允许分页, PageSize=" ...
- 使用Sql分页方法给Repeater控件分页的方法
页面代码 <div class="bookList"> <asp:Repeater ID="rpBooks" runat="serv ...
- asp.net自带的异步刷新控件使用
一直都是使用jquery的$.ajax,由于刚刚加入的公司是用asp.net的,webform与之前的ajax加在一起显得很混乱,后来发现asp.net已经封装了一下ajax功能,就查了一下,并且做了 ...
- Asp.Net 之 母版页中对控件ID的处理
一.问题提出 由于总体排版和设计的需要,我们往往创建母版页来实现整个网站的统一性,最近我由于统一性的需要,把原来整个项目单独的页面全部套用了母版页.但是出现了一系列失效错误. 二. 抽象模型 由于整个 ...
随机推荐
- Odoo 8.0 实施开发指南 第一版 试读
试读地址: http://share.weiyun.com/4f83964db87e022c7c210abe6b5e782f 如有错误,欢迎指正.
- thinkphp条件查询和模糊查询的一些方法
#文章管理 public function adminArticle(){ $adminArticle=M("article"); $arr_seach=$this->sea ...
- 一次有趣的XSS漏洞挖掘分析(1)
最近认识了个新朋友,天天找我搞XSS.搞了三天,感觉这一套程序还是很有意思的.因为是过去式的文章,所以没有图.但是希望把经验分享出来,可以帮到和我一样爱好XSS的朋友.我个人偏爱富文本XSS,因为很有 ...
- Java面试题大全(二)
41.是否可以继承String类? String类是final类故不可以继承. 42.swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上? switch(expr1 ...
- js中if的另类实现
偶然发现一篇有意思的博客<JS利用短路原理简写if语句> 利用&&短路来实现if的简写. 如 1==2&&a1=1,则后面的a1=1不会进行判断,1==1 ...
- WordPress插件开发实例教程 - 版权插件
说明:本教程仅限学习,高手请绕道 开发程序:WordPress 3.9-RC1 使用主题:Twenty Fourteen 在开始之前,需要注意三件事情 I.给插件取一个个性化的名字,越个性化越好,以防 ...
- BizTalk开发系列(三十五) TCP/IP 适配器
BizTalk 的TCP/IP适配器最初是为英国的保健行业开发.该适配器属于BizTalk进程内适配器,将消息通过TCP/IP 套接字符串在BizTalk服务器与远程客户端间进行通讯. TCP/IP适 ...
- 【iCore3 双核心板】例程一:ARM驱动三色LED
实验指导书及代码包下载: http://pan.baidu.com/s/1o6w6Xnk iCore3 购买链接: https://item.taobao.com/item.htm?id=524229 ...
- A trip through the Graphics Pipeline 2011_07_Z/Stencil processing, 3 different ways
In this installment, I’ll be talking about the (early) Z pipeline and how it interacts with rasteriz ...
- wordpress 导航相关的函数
上一篇文章.下一篇文章 previous_post_link( $format = '« %link', $link = '%title', $in_same_term = false, $exclu ...