利用PagedDataSource类实现datalist 分页功能
PagedDataSource类封装数据绑定控件(如 DataGrid、GridView、DetailsView 和 FormView)的与分页相关的属性,以允许该控件执行分页操作。无法继承此类。
AllowCustomPaging 获取或设置一个值,指示是否在数据绑定控件中启用自定义分页。
AllowPaging 获取或设置一个值,指示是否在数据绑定控件中启用分页。
AllowServerPaging 获取或设置一个值,指示是否启用服务器端分页。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页面中显示的首条记录的索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsServerPagingEnabled 获取一个值,指示是否启用服务器端分页支持。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
SyncRoot 获取可用于同步集合访问的对象。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。
ps.AllowPaging = true;
//每页显示10条数据
ps.PageSize = 10;
//设置当前页的索引
ps.CurrentPageIndex = nPage - 1;
if (nPage == 1) //等于第一页
{
this.First.Enabled = false;//不显示第一页按钮
this.Front.Enabled = false;//不显示上一页按钮
}
if (nPage == ps.PageCount) //等于最后一页
{
this.Next.Enabled = false;//不显示下一页
this.Last.Enabled = false;//不显示最后一页
}
this.lPage.Text = Convert.ToString(ps.PageCount);
this.dl2.DataSource = ps;
//设置数据源的关键字段
this.dl2.DataKeyField = "ID";
dl2.DataBind();
}
catch (Exception ex)
{
Response.Write(ex.Message.ToString());
}
}
protected void First_Click(object sender, EventArgs e)
{
laPage.Text = "1";//设置当前页为1
}
protected void Front_Click(object sender, EventArgs e)
{
//设置当前页减1
labPage.Text = Convert.ToString(Convert.ToInt32(laPage.Text) - 1);
}
protected void Next_Click(object sender, EventArgs e)
{
//设置当前页加1
lab.Text = Convert.ToString(Convert.ToInt32(laPage.Text) + 1);
}
protected void Last_Click(object sender, EventArgs e)
{
//设置当前页为最后一页
laPage.Text = labBackPage.Text;
}
}