DataList分页方法的核心原理是利用PagedDataSource对象,下面是PagedDataSource的公共属性:
AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
AllowPaging 获取或设置指示是否启用分页的值。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页中的第一个索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。
如何使用 PagedDataSource对象进行DataList分页?
我想实现的功能是:第一页 上一页 下一页 最后一页 页码:【当前页码/总页码】跳转到:
page.aspx
< ItemTemplate >
<% # DataBinder.Eval(Container.DataItem, " 字段 " ) %>
</ ItemTemplate >
</ asp:DataList >
< table width = " 510 " border = " 0 " cellspacing = " 0 " cellpadding = " 0 " >
< tr >
< td class = " font " >
< asp:LinkButton ID = " linkbtnone " runat = " server " OnClick = " linkbtnone_Click " > 第一页 </ asp:LinkButton >
< asp:LinkButton ID = " linkbtnpre " runat = " server " OnClick = " linkbtnpre_Click " > 上一页 </ asp:LinkButton >
< asp:LinkButton ID = " linkbtnnext " runat = " server " OnClick = " linkbtnnext_Click " > 下一页 </ asp:LinkButton >
< asp:LinkButton ID = " linkbtnlast " runat = " server " OnClick = " linkbtnlast_Click " > 最后一页 </ asp:LinkButton >
< asp:Label ID = " labcp " runat = " server " ></ asp:Label > [ < asp:Label ID = " labpage " runat = " server " Text = " 1 " ></ asp:Label >/< asp:Label ID = " labtp " runat = " server " ></ asp:Label > ]
< asp:Label ID = " labgoto " runat = " server " Text = " 转到: " ></ asp:Label >
< asp:TextBox ID = " txtgo " runat = " server " Height = " 15px " Width = " 30px " ></ asp:TextBox > 页
< asp:Button ID = " BtnGo " runat = " server " Text = " GO " Width = " 36px " OnClick = " BtnGo_Click " />
</ td >
</ tr >
</ table >
page.aspx.cs
{
protected void Page_Load( object sender, EventArgs e)
{
if ( ! IsPostBack)
{
BindHuoList( 25 );
}
}
// 绑定
private void BindHuoList( int length)
{
DataTable dtHuoList = ; // 获取数据
string strLength;
for ( int i = 0 ; i < dtHuoList.Rows.Count; i ++ )
{
strLength = dtHuoList.Rows[i][ " article_title " ].ToString();
if (strLength.Length > length)
{
dtHuoList.Rows[i][ " article_title " ] = (Object)strLength.Substring( 0 , length);
}
}
this .txtgo.Text = "" ;
int curpage = Convert.ToInt32( this .labpage.Text);
PagedDataSource ps = new PagedDataSource(); // 定义PagedDataSource对象
ps.DataSource = dtHuoList.DefaultView; // 取出数据到datatable中,赋给PagedDataSource对象
ps.AllowPaging = true ; // 是否可以分页
ps.PageSize = 16 ; // 显示的数量
ps.CurrentPageIndex = curpage - 1 ; // 取得当前页的页码,PagedDataSource的CurrentPageIndex是从0开始
this .linkbtnone.Enabled = true ;
this .linkbtnpre.Enabled = true ;
this .linkbtnnext.Enabled = true ;
this .linkbtnlast.Enabled = true ;
if (curpage == 1 )
{
this .linkbtnone.Enabled = false ;
this .linkbtnpre.Enabled = false ;
}
if (curpage == ps.PageCount)
{
this .linkbtnnext.Enabled = false ;
this .linkbtnlast.Enabled = false ;
}
this .labtp.Text = Convert.ToString(ps.PageCount); // 显示分页数量
this .DataListHuoList.DataSource = ps; // 绑定DataList控件
this .DataListHuoList.DataKeyField = " article_id " ;
this .DataListHuoList.DataBind();
// 第一页
protected void linkbtnone_Click( object sender, EventArgs e)
{
this .labpage.Text = " 1 " ;
BindHuoList( 25 );
}
// 上一页
protected void linkbtnpre_Click( object sender, EventArgs e)
{
this .labpage.Text = Convert.ToString(Convert.ToInt32( this .labpage.Text) - 1 );
BindHuoList( 25 );
}
// 下一页
protected void linkbtnnext_Click( object sender, EventArgs e)
{
this .labpage.Text = Convert.ToString(Convert.ToInt32( this .labpage.Text) + 1 );
BindHuoList( 25 );
}
// 最后一页
protected void linkbtnlast_Click( object sender, EventArgs e)
{
this .labpage.Text = this .labtp.Text;
BindHuoList( 25 );
}
// 跳转按钮
protected void BtnGo_Click( object sender, EventArgs e)
{
this .labpage.Text = this .txtgo.Text;
BindHuoList( 25 );
}
}