ASP.NETにおけるRepeaterコントロールによるページング機能の実現
6823 ワード
Repeater
,
Repeaterページングは、PagedDataSourceに依存する必要があります.このクラスはSystemに存在する.Web.UI.WebControlsネーミングスペース.データソースとデータ表示コントロールの中間メディアとして機能します.次のようになります.
データソース->PagedDataSource->データバインドコントロール
関係は次のコードで実現されます.
PagedDataSource pds=new PagedDataSource ();
pds.DataSource=dataTable;
repeater1.DataSource=pds;
repeater1.DataBind();
3つの間に関係があるコードはこれらです.
ではPagedDataSourceはどのように機能しているのでしょうか.MSDNにも載っていません.これは私の推測にすぎない.
PagedDataSourceは、下位データ・ソース(DataTableなど)から数ページ目のデータを取り出す中間プロセスをカプセル化します.設定するだけです
PagedDataSource .AllowPaging=true;
PagedDataSource .PageSize=xx;
PagedDataSource.CurrentPageIndex=currentPage;
指定したページのデータを取り出すことができ、データバインドコントロールはPagedDataSourceからこれらのデータを取得して表示します.PagedDataSourceはここで仲介をしています.データバインディングコンポーネントはどのようにデータを取り、PagedDataSourceはどのようにページを分け、対応するデータを取り出します.これはaspです.Netフレームワークの内部実装は、私たちに完全に透明です.
もう1つ重要なのは、PagedDataSourceのページ番号は0から始まり、1から始まるわけではありません.
次に例を示します.
フロントのコード:
//repeate.aspx
次はバックグラウンドのコードです.
//repeate.aspx.cs
using System;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class repeate : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Repeater1.DataSource = pds();
Repeater1.DataBind();
}
}
private PagedDataSource pds()
{
string connstring = ConfigurationManager.ConnectionStrings["pconn"].ConnectionString;
SqlConnection con = new SqlConnection(connstring);
DataSet ds = new DataSet();
SqlDataAdapter sda = new SqlDataAdapter("select * from authors",con);
sda.Fill(ds,"name");
SqlDataAdapter sda2 = new SqlDataAdapter("select * from titleauthor",con);
sda2.Fill(ds,"title");
ds.Relations.Add("myrela",ds.Tables["name"].Columns["au_id"],ds.Tables["title"].Columns["au_id"]);
PagedDataSource pds = new PagedDataSource();
pds.DataSource = ds.Tables["name"].DefaultView;
pds.AllowPaging = true;//
pds.PageSize = 5;//
pds.CurrentPageIndex = Convert.ToInt32(Request.QueryString["page"]);
return pds;
}
protected void Repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Footer)
{
DropDownList ddlp = (DropDownList)e.Item.FindControl("ddlp");
HyperLink lpfirst = (HyperLink)e.Item.FindControl("hlfir");
HyperLink lpprev = (HyperLink)e.Item.FindControl("hlp");
HyperLink lpnext = (HyperLink)e.Item.FindControl("hln");
HyperLink lplast = (HyperLink)e.Item.FindControl("hlla");
pds().CurrentPageIndex = ddlp.SelectedIndex;
int n = Convert.ToInt32(pds().PageCount);//n
int i = Convert.ToInt32(pds().CurrentPageIndex);//i
Label lblpc = (Label)e.Item.FindControl("lblpc");
lblpc.Text = n.ToString();
Label lblp = (Label)e.Item.FindControl("lblp");
lblp.Text = Convert.ToString(pds().CurrentPageIndex + 1);
if (!IsPostBack)
{
for (int j = 0; j < n; j++)
{
ddlp.Items.Add(Convert.ToString(j + 1));
}
}
if (i <= 0)
{
lpfirst.Enabled = false;
lpprev.Enabled = false;
lplast.Enabled = true;
lpnext.Enabled = true;
}
else
{
lpprev.NavigateUrl = "?page=" + (i - 1);
}
if (i >= n - 1)
{
lpfirst.Enabled = true;
lplast.Enabled = false;
lpnext.Enabled = false;
lpprev.Enabled = true;
}
else
{
lpnext.NavigateUrl = "?page=" + (i + 1);
}
lpfirst.NavigateUrl = "?page=0";// page
lplast.NavigateUrl = "?page=" + (n - 1);
ddlp.SelectedIndex = Convert.ToInt32(pds().CurrentPageIndex);//
}
}
protected void ddlp_SelectedIndexChanged(object sender, EventArgs e)
{//
string pg=Convert.ToString((Convert.ToInt32(((DropDownList)sender).SelectedValue)-1));//
Response.Redirect("repeate.aspx?page="+pg);//
}
}