我已经阅读了几篇文章和教程,但我就是无法弄清楚这一点。 一切基本上都在说:“哦,只要打开AllowPaging,就完成了!” 当我这样做时,是的,我可以在设计视图中的 GridView 下看到分页控件,但是当我编译时,我看不到正在运行的站点中的页码。
我注意到与所有示例不同的一件事是,我从代码隐藏中进行数据工作。 因此我的 GridView 很简单:
<asp:GridView ID="gvlatest" runat="server" Width="99%" AllowSorting="True"
onrowdatabound="gvlatest_RowDataBound" onsorting="gvlatest_Sorting"
AllowPaging="True" PageSize="2" />
我所说的从后面进行数据工作的意思是,所有列和所有内容都是从代码构建到 DataTable 中,然后我将 GridView 的 DataSource 设置为 DataTable。 例如,我所拥有的内容的严重缩写版本:
DataTable temptable = new DataTable();
DataColumn titlecol = new DataColumn();
titlecol.ColumnName = "Title";
temptable.Columns.Add(titlecol);
gvlatest.DataSource = temptable;
gvlatest.DataBind();
我想这只是个人喜好,说实话,我实际上从未学习过如何使用 DataSource 控件,因此所有示例都在使用,在 .aspx 文件中使用列、数据构建 GridView来源等。所以我猜测我的问题在于那个大方向......
问题是,我做错了什么? 为什么页码不显示? 将“AllowPaging”设置为 true 真的就是我需要做的吗?
为了使分页正常工作,您的数据源必须支持它。如果没有,就像 DataTable 一样,那么您必须自己执行此操作。
此代码应该有帮助。
OnPageIndexChanging="myGridview_PageIndexChanging"
protected void myGridview_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
GridView gv = (GridView)sender;
DataView dv = gv.DataSource as DataView;
DataTable dataTable = dv.Table;
gv.DataSource = myDataTable;
gv.PageIndex = e.NewPageIndex;
gv.DataBind();
}
您可以禁用特定列并添加分页
protected void Gridview1_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == System.Web.UI.WebControls.DataControlRowType.DataRow)
//----------------------------------Grid view column invisible------------------------------------------------------------
if (Request.QueryString.Get("show") == "all")
GridView1.Columns[0].Visible = true;
else
GridView1.Columns[0].Visible = false;
//-------------------------------------------------------------------------------------------------------------------------
}
protected void Gridview1_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
GridView1.PageIndex = e.NewPageIndex;
gvbind();// Grid View Binded
}
// Source Code
allowpaging="true" OnPageIndexChanging="Gridview1_PageIndexChanging" pagesize="2"