一、實現分頁功能
GridView實現分頁只需要在屬性框中將AllowPaging(是否在GridView中打開分頁功能)設置為true即可
有時打開分頁后不顯示頁碼
確保AllowCustomPaging(是否打開對自定義分頁的支持)為False即可
二、實現翻頁功能
如何點擊頁碼實現翻頁呢?
在屬性框中事件選擇設置PageIndexChanging(在Grid View的當前索引頁正在更改事觸發)這一事件
后台代碼如下
/// <summary> /// 翻頁操作 /// 在GridView當前索引正在更改時觸發 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) { GridView1.PageIndex = e.NewPageIndex; InitGridView(); }
三、實現自定義翻頁頁碼功能
gridView自帶的頁碼樣式看起起來簡單了些,在這里換種樣式可以更好些。
如實現下圖效果
前台<asp:GridView></asp:GridView>代碼內的最后添加如下代碼
<PagerTemplate> 當前第: <%--//((GridView)Container.NamingContainer)就是為了得到當前的控件--%> <asp:Label ID="LabelCurrentPage" runat="server" Text="<%# ((GridView)Container.NamingContainer).PageIndex + 1 %>"></asp:Label> 頁/共: <%--//得到分頁頁面的總數--%> <asp:Label ID="LabelPageCount" runat="server" Text="<%# ((GridView)Container.NamingContainer).PageCount %>"></asp:Label> 頁 <%--//如果該分頁是首分頁,那么該連接就不會顯示了.同時對應了自帶識別的命令參數CommandArgument--%> <asp:LinkButton ID="LinkButtonFirstPage" runat="server" CommandArgument="First" CommandName="Page" Visible='<%#((GridView)Container.NamingContainer).PageIndex != 0 %>'>首頁</asp:LinkButton> <asp:LinkButton ID="LinkButtonPreviousPage" runat="server" CommandArgument="Prev" CommandName="Page" Visible='<%# ((GridView)Container.NamingContainer).PageIndex != 0 %>'>上一頁</asp:LinkButton> <%--//如果該分頁是尾頁,那么該連接就不會顯示了--%> <asp:LinkButton ID="LinkButtonNextPage" runat="server" CommandArgument="Next" CommandName="Page" Visible='<%# ((GridView)Container.NamingContainer).PageIndex != ((GridView)Container.NamingContainer).PageCount - 1 %>'>下一頁</asp:LinkButton> <asp:LinkButton ID="LinkButtonLastPage" runat="server" CommandArgument="Last" CommandName="Page" Visible='<%# ((GridView)Container.NamingContainer).PageIndex != ((GridView)Container.NamingContainer).PageCount - 1 %>'>尾頁</asp:LinkButton> 轉到第 <asp:TextBox ID="txtNewPageIndex" runat="server" Width="20px" Text='<%# ((GridView)Container.Parent.Parent).PageIndex + 1 %>' />頁 <%--//這里將CommandArgument即使點擊該按鈕e.newIndex 值為3 --%> <asp:LinkButton ID="btnGo" runat="server" CausesValidation="False" CommandArgument="-2" CommandName="Page" Text="GO" /> </PagerTemplate> </asp:GridView>
后台代碼如下,附帶了書寫過程中嘗試過的方法供參考一下
/// <summary> /// 翻頁操作 /// 在GridView當前索引正在更改時觸發 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) { #region 方法1 廢棄 //txtName.Text = "翻頁操作"; //int index = e.NewPageIndex+1; //DataSet ds = SplitDataSet(index); //DataTable dt = ds.Tables[0]; ////DataGrid1.DataSource = dt; ////DataGrid1.DataBind(); //GridView1.DataSource = dt; //GridView1.DataBind(); //ClearDisplay(); //GridView1.AllowCustomPaging = false; #endregion #region 方法2 //GridView1.PageIndex = e.NewPageIndex; //InitGridView(); #endregion #region 方法3 #region 前台 //<PagerTemplate> // 當前第: // <%--//((GridView)Container.NamingContainer)就是為了得到當前的控件--%> // <asp:Label ID="LabelCurrentPage" runat="server" Text="<%# ((GridView)Container.NamingContainer).PageIndex + 1 %>"></asp:Label> // 頁/共: // <%--//得到分頁頁面的總數--%> // <asp:Label ID="LabelPageCount" runat="server" Text="<%# ((GridView)Container.NamingContainer).PageCount %>"></asp:Label> // 頁 // <%--//如果該分頁是首分頁,那么該連接就不會顯示了.同時對應了自帶識別的命令參數CommandArgument--%> // <asp:LinkButton ID="LinkButtonFirstPage" runat="server" CommandArgument="First" CommandName="Page" // Visible='<%#((GridView)Container.NamingContainer).PageIndex != 0 %>'>首頁</asp:LinkButton> // <asp:LinkButton ID="LinkButtonPreviousPage" runat="server" CommandArgument="Prev" // CommandName="Page" Visible='<%# ((GridView)Container.NamingContainer).PageIndex != 0 %>'>上一頁</asp:LinkButton> // <%--//如果該分頁是尾頁,那么該連接就不會顯示了--%> // <asp:LinkButton ID="LinkButtonNextPage" runat="server" CommandArgument="Next" CommandName="Page" // Visible='<%# ((GridView)Container.NamingContainer).PageIndex != ((GridView)Container.NamingContainer).PageCount - 1 %>'>下一頁</asp:LinkButton> // <asp:LinkButton ID="LinkButtonLastPage" runat="server" CommandArgument="Last" CommandName="Page" // Visible='<%# ((GridView)Container.NamingContainer).PageIndex != ((GridView)Container.NamingContainer).PageCount - 1 %>'>尾頁</asp:LinkButton> // 轉到第 // <asp:TextBox ID="txtNewPageIndex" runat="server" Width="20px" Text='<%# ((GridView)Container.Parent.Parent).PageIndex + 1 %>' />頁 // <%--//這里將CommandArgument即使點擊該按鈕e.newIndex 值為3 --%> // <asp:LinkButton ID="btnGo" runat="server" CausesValidation="False" CommandArgument="-2" // CommandName="Page" Text="GO" /> //</PagerTemplate> #endregion // 得到該控件 GridView theGrid = sender as GridView; int newPageIndex = 0; if (e.NewPageIndex == -3) { //點擊了Go按鈕 TextBox txtNewPageIndex = null; //GridView較DataGrid提供了更多的API,獲取分頁塊可以使用BottomPagerRow 或者TopPagerRow,當然還增加了HeaderRow和FooterRow GridViewRow pagerRow = theGrid.BottomPagerRow; if (pagerRow != null) { //得到text控件 txtNewPageIndex = pagerRow.FindControl("txtNewPageIndex") as TextBox; } if (txtNewPageIndex != null) { //得到索引 newPageIndex = int.Parse(txtNewPageIndex.Text) - 1; } } else { //點擊了其他的按鈕 newPageIndex = e.NewPageIndex; } //防止新索引溢出 newPageIndex = newPageIndex < 0 ? 0 : newPageIndex; newPageIndex = newPageIndex >= theGrid.PageCount ? theGrid.PageCount - 1 : newPageIndex; //得到新的值 theGrid.PageIndex = newPageIndex; //重新綁定 InitGridView(); #endregion }