Fuente: columna de snooker_li.
Recientemente creé un programa de álbum de fotos que requería paginación con frecuencia, así que quería escribir un control de usuario.
El código es el siguiente:
Página AutoPage.ascx
<%@ Control Language="c#" AutoEventWireup="false" Codebehind="AutoPage.ascx.cs" Inherits="album.AutoPage" TargetSchema=" http://schemas.microsoft .com/intellisense/ie5 " %>
<table border="0" cellpadding="0" cellspace="0">
<tr>
<td valign="middle" height="30">Total de registros de <asp:label id="lb_ItemCount" ForeColor="Red" runat="server"></asp:label></td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_First" runat="server">Página de inicio</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Prev" runat="server">Página anterior</asp:hyperlink> </td>
<td valign="middle" height="30">Actual<asp:label id="lb_CurrentPage" runat="server"></asp:label>páginas/total<asp:label id="lb_PageCount" runat=" servidor"></asp:label>página</td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Next" runat="server">Página siguiente</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Last" runat="server">Última página</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:textbox id="txb_Page" runat="servidor" Ancho="32px" BorderStyle="Sólido" BorderWidth="1px"
BorderColor="Plata"></asp:textbox></td>
<td valign="middle" height="30"><asp:ImageButton id="btn_go" runat="servidor" ImageUrl="album_images/go.gif"></asp:ImageButton></td>
<td valign="middle" height="30"><asp:label id="lb_url" runat="servidor" Visible="False"></asp:label><asp:Label id="lb_Params" runat= "servidor" Visible="False"></asp:Label></td>
</tr>
</table>
Álbum de espacio de nombres
de página AutoPage.ascx.cs
{
usando Sistema;
usando System.Data;
usando System.Drawing;
usando System.Web;
usando System.Web.UI.WebControls;
usando System.Web.UI.HtmlControls;
usando System.Data.SqlClient
/// <resumen>
/// Descripción resumida de UC.
/// </summary>
AutoPágina de clase pública: System.Web.UI.UserControl
{
sistema protegido.Web.UI.WebControls.HyperLink hpl_First;
System.Web.UI.WebControls.HyperLink protegido hpl_Prev;
Sistema protegido.Web.UI.WebControls.HyperLink hpl_Next;
protegido System.Web.UI.WebControls.Label lb_CurrentPage;
protegido System.Web.UI.WebControls.Label lb_PageCount;
sistema protegido.Web.UI.WebControls.HyperLink hpl_Last;
tamaño de página int público;
página de cadena públicaP;
System.Web.UI.WebControls.TextBox txb_Page protegido;
protegido System.Web.UI.WebControls.Label lb_url;
protegido System.Web.UI.WebControls.Label lb_ItemCount;
URL de cadena pública;
protegido System.Web.UI.WebControls.Label lb_Params;
Sistema protegido.Web.UI.WebControls.ImageButton btn_go;
Parámetros de cadena pública;
Page_Load vacío privado (remitente del objeto, System.EventArgs e)
{
}
enlace de datos público PagedDataSource (DataTable dt)
{
lb_url.Texto = URL;
lb_Params.Text = Parámetros;
//Crear clase de paginación
PagedDataSource objPage = nuevo PagedDataSource();
//Establecer fuente de datos
objPage.DataSource = dt.DefaultView;
//Permitir paginación
objPage.AllowPaging = verdadero;
//Establece el número de elementos que se muestran en cada página
objPage.PageSize = tamaño de página;
//Establece el índice de la página actual
int PáginaCur=1;
intentar
{
CurPage = Convert.ToInt32(PageP);
si (CurPage<1 || CurPage>objPage.PageCount)
{
Response.Redirect(url+"?page=1"+Params);
}
}
atrapar
{
Response.Redirect(url+"?page=1"+Params);
}
objPage.CurrentPageIndex = CurPage-1;
//Mostrar información de estado
lb_ItemCount.Text = dt.Rows.Count.ToString();
lb_CurrentPage.Text = CurPage.ToString();
lb_PageCount.Text =objPage.PageCount.ToString();
//Si la página actual no es la página de inicio
si (!objPage.IsFirstPage)
{
hpl_Prev.NavigateUrl=url + "?Page=" + Convert.ToString(CurPage-1)+Params;
hpl_First.NavigateUrl=url + "?Página=1"+Params;
}
//Si la página actual no es la última página
si (!objPage.IsLastPage)
{
hpl_Next.NavigateUrl=url+ "?Page=" + Convert.ToString(CurPage+1)+Params;
hpl_Last.NavigateUrl=url + "?Page=" +objPage.PageCount.ToString()+Params;
}
devolver páginaobj;
}
#region Código generado por el diseñador de formularios web
anular el vacío protegido OnInit (EventArgs e)
{
//
// CODEGEN: esta llamada la requiere el diseñador de formularios web ASP.NET.
//
InicializarComponente();
base.OnInit(e);
}
/// <resumen>
/// Designer admite los métodos requeridos; no use el editor de código
/// Modifica el contenido de este método.
/// </summary>
vacío privado InicializarComponente()
{
this.btn_go.Click += nuevo System.Web.UI.ImageClickEventHandler(this.btn_go_Click);
this.Load += nuevo System.EventHandler(this.Page_Load)
;
#endregion
private void btn_go_Click (remitente del objeto, System.Web.UI.ImageClickEventArgs e)
{
Response.Redirect(lb_url.Text+"?Page="+txb_Page.Text+lb_Params.Text);
}
}
}
Al
llamar, debe configurar varios parámetros: tamaño de página (la cantidad de datos que se muestran en cada página), PageP (parámetros de paginación pasados), ParmP (otros parámetros de Request.QureyString) y URL (dirección de página).
necesita vincular el control DataSource=AutoPage1.databind(variable DataTable)