出典: snooker_li のコラム
最近、頻繁にページングを必要とするフォト アルバム プログラムを作成したので、ユーザー コントロールを作成したいと思いました。
コードは次のとおりです。
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" cellpacing="0">
<tr>
<td valign="middle" height="30">合計 <asp:label id="lb_ItemCount" ForeColor="Red" runat="server"></asp:label> レコード </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_First" runat="server">ホームページ</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Prev" runat="server">前のページ</asp:hyperlink> </td>
<td valign="middle" height="30">現在の<asp:label id="lb_CurrentPage" runat="server"></asp:label>ページ/合計<asp:label id="lb_PageCount" runat="サーバー"></asp:label>ページ </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Next" runat="server">次のページ</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:hyperlink id="hpl_Last" runat="server">最後のページ</asp:hyperlink> </td>
<td valign="middle" height="30"><asp:textbox id="txb_Page" runat="server" width="32px" BorderStyle="Solid" BorderWidth="1px"
BorderColor="Silver"></asp:textbox></td>
<td valign="middle" height="30"><asp:ImageButton id="btn_go" runat="server" ImageUrl="album_images/go.gif"></asp:ImageButton></td>
<td valign="middle" height="30"><asp:label id="lb_url" runat="server" Visible="False"></asp:label><asp:Label id="lb_Params" runat= "server" Visible="False"></asp:Label></td>
</tr>
</table>
AutoPage.ascx.cs ページ
名前空間アルバム
{
システムを使用する;
System.Data を使用します。
System.Drawing を使用します。
System.Web を使用します。
System.Web.UI.WebControls を使用します。
System.Web.UI.HtmlControls を使用します。
System.Data.SqlClient を使用します。
/// <概要>
/// UC の概要説明。
/// </概要>
パブリック クラス AutoPage : System.Web.UI.UserControl
{
protected System.Web.UI.WebControls.HyperLink hpl_First;
protected System.Web.UI.WebControls.HyperLink hpl_Prev;
protected System.Web.UI.WebControls.HyperLink hpl_Next;
protected System.Web.UI.WebControls.Label lb_CurrentPage;
protected System.Web.UI.WebControls.Label lb_PageCount;
protected System.Web.UI.WebControls.HyperLink hpl_Last;
public int ページサイズ;
パブリック文字列 PageP;
protected System.Web.UI.WebControls.TextBox txb_Page;
protected System.Web.UI.WebControls.Label lb_url;
protected System.Web.UI.WebControls.Label lb_ItemCount;
パブリック文字列 URL;
protected System.Web.UI.WebControls.Label lb_Params;
protected System.Web.UI.WebControls.ImageButton btn_go;
public string Params;
private void Page_Load(オブジェクト送信者、System.EventArgs e)
{
public PagedDataSource databind(DataTable dt
)
{
lb_url.Text = URL;
lb_Params.Text = パラメータ;
//ページングクラスを作成する
PagedDataSource objPage = new PagedDataSource();
//データソースを設定する
objPage.DataSource = dt.DefaultView;
//ページングを許可する
objPage.AllowPaging = true;
//各ページに表示されるアイテムの数を設定します
objPage.PageSize = ページサイズ;
// 現在のページのインデックスを設定します
int CurPage=1;
試す
{
CurPage = Convert.ToInt32(PageP);
if (CurPage<1 || CurPage>objPage.PageCount)
{
Response.Redirect(url+"?page=1"+Params);
}
}
キャッチ
{
Response.Redirect(url+"?page=1"+Params);
}
objPage.CurrentPageIndex = CurPage-1;
//ステータス情報を表示する
lb_ItemCount.Text = dt.Rows.Count.ToString();
lb_CurrentPage.Text = CurPage.ToString();
lb_PageCount.Text =objPage.PageCount.ToString();
// 現在のページがホームページではない場合
if (!objPage.IsFirstPage)
{
hpl_Prev.NavigateUrl=url + "?Page= + Convert.ToString(CurPage-1)+Params;
hpl_First.NavigateUrl=url + "?Page=1"+Params;
}
// 現在のページが最後のページでない場合
if (!objPage.IsLastPage)
{
hpl_Next.NavigateUrl=url+ "?Page= + Convert.ToString(CurPage+1)+Params;
hpl_Last.NavigateUrl=url + "?Page= +objPage.PageCount.ToString()+Params;
}
objPage を返します。
}
#region Web フォーム デザイナーが生成したコード
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: この呼び出しは、ASP.NET Web フォーム デザイナーに必要です。
//
InitializeComponent();
Base.OnInit(e);
}
/// <概要>
/// デザイナーは必要なメソッドをサポートします - コード エディターを使用しないでください
/// このメソッドの内容を変更します。
/// </概要>
private void InitializeComponent()
{
this.btn_go.Click += new System.Web.UI.ImageClickEventHandler(this.btn_go_Click);
this.Load += 新しい System.EventHandler(this.Page_Load)
;
#endregion
private void btn_go_Click(オブジェクト送信者、System.Web.UI.ImageClickEventArgs e)
{
Response.Redirect(lb_url.Text+"?Page="+txb_Page.Text+lb_Params.Text);
}
}
、
いくつかのパラメーター、pagesize (各ページに表示されるデータの数)、PageP (渡されたページング パラメーター)、ParmP (その他の Request.QureyString パラメーター)、および url (ページ アドレス) を設定する必要が
あるのは、バインドするときだけです
。コントロール DataSource=AutoPage1.databind(DataTable 変数) をバインドする必要があります