时间:2021-07-01 10:21:17 帮助过:25人阅读
这是我写的一个分页控件,功能如下:
1.支持设计时支持和两种分页模式,其中综合分页模式的效果如下:
普通分页模式的效果如下:
2.完善的设计时支持,包括自动套用格式和设计时面板设置:
使用方法:
在aspx页面中:
代码如下:
- <br><%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="Cyclone.CustomPager.WebApplication._Default" %> <br><%@ Register assembly="Cyclone.CustomPager.Pager" namespace="Cyclone.CustomPager.Pager" tagprefix="Cyclone" %> <br><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <br><html xmlns="http://www.w3.org/1999/xhtml" > <br><head runat="server"> <br><title></title> <br><link type="text/css" rel="stylesheet" href="style/comm.css" /> <br></head> <br><body> <br><form id="form1" runat="server"> <br><div> <br> <br><asp:GridView ID="GridView1" runat="server" AllowPaging="false" AutoGenerateColumns="False" CellPadding="4" ForeColor="#333333" GridLines="None" PagerSettings-Visible="false" <br>Width="80%" height="35" DataKeyNames="ID"> <br><FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> <br><RowStyle BackColor="#EFF3FB" /> <br><EditRowStyle BackColor="#2461BF" /> <br><SelectedRowStyle BackColor="#D1DDF1" Font-Bold="True" ForeColor="#333333" /> <br><PagerStyle ForeColor="White" VerticalAlign="Top" BackColor="Transparent" /> <br><HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> <br><AlternatingRowStyle BackColor="White" /> <br><Columns> <br><asp:TemplateField HeaderText="序号"> <br><ItemTemplate> <br><%# Container.DataItemIndex+1 %> <br></ItemTemplate> <br></asp:TemplateField> <br><asp:BoundField DataField="ID" HeaderText="用户ID" /> <br><asp:BoundField DataField="UserName" HeaderText="用户名" /> <br><asp:BoundField DataField="Email" HeaderText="Email" /> <br><asp:BoundField DataField="Address" HeaderText="地址" /> <br></Columns> <br></asp:GridView> <br></div> <br><div> <br><Cyclone:AspNetPager ID="AspNetPager1" runat="server" ButtonText="GO" EndPageText="末页" <br>FirstPageText="首页" NextPageText="下一页" PageSize="15" PrePageText="上一页" OnPageChanged="Page_Changed" Width="80%" PageMode=Normal BackColor="#FFE0C0" BorderColor="#FFC0C0" BorderStyle="Solid" BorderWidth="1px" ForeColor="#804040"> <br><ButtonStyle CssClass="btn1_mouseout" Width="30px" /> <br><TextBoxStyle Width="30px" CssClass="blue_rounded"/> <br><LabelStyle ForeColor="Red" Font-Bold="True" /> <br></Cyclone:AspNetPager> <br> <br></div> <br></form> <br></body> <br></html> <br><br>在后台代码中: <br><span><u></u></span> 代码如下:<br>using System; <br>using System.Collections.Generic; <br>using System.Linq; <br>using System.Web; <br>using System.Web.UI; <br>using System.Web.UI.WebControls; <br>using System.Data; <br>namespace Cyclone.CustomPager.WebApplication <br>{ <br>public partial class _Default : System.Web.UI.Page <br>{ <br>private List<User> _data=new List<User>(); <br>protected override void OnInit(EventArgs e) <br>{ <br>base.OnInit(e); <br>this.GetData(); <br>} <br>protected void Page_Load(object sender, EventArgs e) <br>{ <br>if (!Page.IsPostBack) <br>{ <br>BindData(); <br>this.AspNetPager1.PageIndex = 1; <br>} <br>} <br>private void GetData() <br>{ <br>for (int i = 0; i < 1000; i++) <br>{ <br>this._data.Add(new User { ID = i + 1, Address = "北京市海淀区", Email = "mickjacksonfeng@163.com", UserName = "凭海观澜" }); <br>} <br>} <br>protected void Page_Changed(object sender, EventArgs e) <br>{ <br>BindData(); <br>} <br>#region 绑定试卷定义方案列表 <br>/// <summary> <br>/// 根据当前页码查询需要的数据 <br>/// </summary> <br>/// <param name="pageIndex">页码</param> <br>private void BindData() <br>{ <br>this.AspNetPager1.RecordCount = this._data.Count; <br>List<User> users = this._data.Skip(this.AspNetPager1.PageSize*(this.AspNetPager1.PageIndex-1)).Take(this.AspNetPager1.PageSize).ToList(); <br>GridView1.DataSource = users; <br>GridView1.DataBind(); <br>} <br>#endregion <br>} <br>public class User <br>{ <br>public int ID { get; set; } <br>public string UserName { get; set; } <br>public string Email { get; set; } <br>public string Address { get; set; } <br>} <br>} <br><br>另外: <br><br>本分页控件还包含简单属性,复杂属性,自定义视图状态,分页事件,创建控件,render控件,Attribute,设计时支持等比较齐全的自定义控件的元素,是个不错学习自定义控件开发的例子,详细代码可以到下面进行下载: 脚本之家下载地址<p></p>