我已经阅读了几篇文章和教程,但我无法理解这一点。一切都基本上说,“哦,只需打开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?
答案 0 :(得分:3)
要使分页正常工作,您的数据源必须支持它。如果没有,就像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();
}
答案 1 :(得分:0)
答案 2 :(得分:0)
您可以停用特定列并添加分页
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"