1、moonPage.ascx:
<%@ Control Language="c#" AutoEventWireup="false" Codebehind="moonPage.ascx.cs" Inherits="firstcs_03.moonPage" TargetSchema="http://schemas.microsoft.com/intellisense/ie5"%>
<TABLE id="Table1" cellSpacing="1" cellPadding="1" width="98%" border="0">
<TR>
<TD align="right"><asp:linkbutton id="FirstPage" runat="server">[首页]</asp:linkbutton>
<asp:linkbutton id="PrevPage" runat="server">[上页]</asp:linkbutton>
<asp:linkbutton id="NextPage" runat="server">[下页]</asp:linkbutton>
<asp:linkbutton id="LastPage" runat="server">[末页]</asp:linkbutton>
<asp:literal id="Literal1" runat="server" Text="转到第"></asp:literal><asp:textbox id="NewPageIndex" runat="server" Width="31px" CssClass="input1"></asp:textbox><asp:literal id="Literal2" runat="server" Text="页"></asp:literal>
<asp:button id="NewPageGo" runat="server" Text="Go" CssClass="input1"></asp:button> </TD>
</TR>
</TABLE>
2、moonPage.ascx.cs
namespace firstcs_03
data:image/s3,"s3://crabby-images/48082/480827fd31e8b7b402626a1c9435fe224b9ef3bd" alt="" {
using System;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" /**//// <summary>
/// moonPage 的摘要说明。
/// </summary>
public class moonPage : System.Web.UI.UserControl
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
protected System.Web.UI.WebControls.LinkButton FirstPage;
protected System.Web.UI.WebControls.LinkButton PrevPage;
protected System.Web.UI.WebControls.LinkButton NextPage;
protected System.Web.UI.WebControls.LinkButton LastPage;
protected System.Web.UI.WebControls.Literal Literal1;
protected System.Web.UI.WebControls.TextBox NewPageIndex;
protected System.Web.UI.WebControls.Literal Literal2;
protected System.Web.UI.WebControls.Button NewPageGo;
protected int currentpage;
protected int pagesize;
protected string proc;
protected System.Web.UI.WebControls.DataGrid datagrid;
data:image/s3,"s3://crabby-images/c67c4/c67c49437c5b327ee09f4b45cc895d0e67733651" alt="" #region 自定义
public int _CurrentPage
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
get
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
return currentpage;
}
set
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
currentpage = value;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
public int _pageSize
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
get
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
return pagesize;
}
set
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
pagesize = value;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
public string _proc
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
get
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
return proc;
}
set
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
proc = value;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
public DataGrid _datagrid
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
get
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
return datagrid;
}
set
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
datagrid = value;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
protected int rowcount;
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
#endregion
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
private void Page_Load(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
if(!IsPostBack)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
using(SqlConnection conn = new SqlConnection("uid=sa;pwd=sa;server=localhost;initial catalog=pubs;timeout=90"))
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
SqlCommand cmd = new SqlCommand("select count(*) as expr1 from authors",conn);
cmd.Connection.Open();
rowcount = (int)cmd.ExecuteScalar();
cmd.Connection.Close();
ViewState["rowscount"] = rowcount;
}
ViewState["currentpage"] = currentpage;
FillGrid(proc,currentpage,pagesize,datagrid);
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
data:image/s3,"s3://crabby-images/c67c4/c67c49437c5b327ee09f4b45cc895d0e67733651" alt="" #region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" /**//// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器
/// 修改此方法的内容。
/// </summary>
private void InitializeComponent()
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
this.FirstPage.Click += new System.EventHandler(this.FirstPage_Click);
this.NextPage.Click += new System.EventHandler(this.NextPage_Click);
this.NewPageGo.Click += new System.EventHandler(this.NewPageGo_Click);
this.Load += new System.EventHandler(this.Page_Load);
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
}
#endregion
private void FillGrid(string proc,int currentpage,int pagesize,DataGrid datagrid)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
using(SqlConnection conn = new SqlConnection("Uid=sa;pwd=sa;server=localhost;initial catalog=pubs;timeout=90"))
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
SqlCommand cmd = new SqlCommand(proc,conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@CurrentPage",currentpage);
cmd.Parameters.Add("@PageSize",pagesize);
cmd.Connection.Open();
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
SqlDataReader sdr = cmd.ExecuteReader();
datagrid.DataSource = sdr;
datagrid.DataBind();
sdr.Close();
cmd.Connection.Close();
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
//首页
private void FirstPage_Click(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
//disabled首页按钮和上一页按钮
FirstPage.Enabled = false;
PrevPage.Enabled = false;
currentpage = 0;
ViewState["currentpage"] = currentpage;
FillGrid(proc,currentpage,pagesize,datagrid);
//如果不止一页
if((int)ViewState["rowscount"]>((int)ViewState["currentpage"]+1)*pagesize)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
NextPage.Enabled = true;
}
if((int)ViewState["rowscount"]>((int)ViewState["currentpage"]+1)*pagesize)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
LastPage.Enabled = true;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
//上一页
private void PrevPage_Click(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
NextPage.Enabled = true;
LastPage.Enabled = true;
currentpage = (int)ViewState["currentpage"]-1;
ViewState["currentpage"] = currentpage;
FillGrid(proc,currentpage,pagesize,datagrid);
//如果到首页则disabled首页和上一页按钮
if((int)ViewState["currentpage"]==0)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
PrevPage.Enabled = false;
FirstPage.Enabled = false;
//return;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
//下一页
private void NextPage_Click(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
ViewState["currentpage"] = (int)ViewState["currentpage"]+1;
currentpage = (int)ViewState["currentpage"];
FillGrid(proc,currentpage,pagesize,datagrid);
PrevPage.Enabled = true;
FirstPage.Enabled = true;
//如果已经到了最后一页
if(((int)ViewState["currentpage"]+1)*pagesize>(int)ViewState["rowscount"])
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
NextPage.Enabled = false;
LastPage.Enabled = false;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
//末页
private void LastPage_Click(object sender, System.EventArgs e)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
LastPage.Enabled = false;
NextPage.Enabled = false;
ViewState["currentpage"] = (int)Math.Ceiling((int)ViewState["rowscount"]/pagesize);
currentpage = (int)ViewState["currentpage"];
FillGrid(proc,currentpage,pagesize,datagrid);
//如果有不止一页的纪录
if((int)ViewState["currentpage"]>1)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
FirstPage.Enabled = true;
PrevPage.Enabled = true;
}
//如果只有一页的纪录
else
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
FirstPage.Enabled = false;
PrevPage.Enabled = false;
}
}
//跳转
private void NewPage_Go(string i)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
try
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
int PageIndex = Int32.Parse(i);
if (PageIndex<=0)
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
PageIndex = 0;
}
else
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
if(PageIndex>(int)Math.Ceiling((int)ViewState["rowscount"]/pagesize))
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
PageIndex = (int)Math.Ceiling((int)ViewState["rowscount"]/pagesize);
}
else
data:image/s3,"s3://crabby-images/4eb31/4eb312750a57dcaee38171ffedf3313374b6c0b0" alt="" {
PageIndex--;
}
}
//简单起见,将所有的linkbutton全部改为enable=true
FirstPage.Enabled = true;
NextPage.Enabled = true;
LastPage.Enabled = true;
PrevPage.Enabled = true;
ViewState["currentpage"] = PageIndex;
FillGrid(proc,(int)ViewState["currentpage"],pagesize,datagrid);
}
catch(Exception)
{
return;
}
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
private void NewPageGo_Click(object sender, System.EventArgs e)
{
NewPage_Go(NewPageIndex.Text.Trim());
}
data:image/s3,"s3://crabby-images/90b72/90b72483eb81393fd03c266640f130cb52dc80ee" alt="自定义ascx文件来控制分页"
}
}
|