ASP.NET GridView 自定义分页

<asp:GridView ID="GridView2" runat="server" AllowPaging="True">
  <PagerTemplate>
       <div id="main">
           <table>
            <tr>
                <td style="text-align:left;">
                    <div id="info">&nbsp;&nbsp;页次:<asp:Label ID="lblPageCurrent" runat="server" Text="1" CssClass="txtInfo"></asp:Label>
                      /<asp:Label ID="lblPageCount" runat="server" Text="1"></asp:Label>&nbsp;&nbsp;
                      共&nbsp;<asp:Label ID="lblPageRow" runat="server" Text="1" CssClass="txtInfo"></asp:Label>&nbsp;条记录
                    </div>
                </td>
                <td style="text-align:right;">
                    <div id="page">
                      <asp:LinkButton ID="btnFirst" runat="server" CssClass="link" CommandName="Pager" CommandArgument="First" OnCommand="NavigateToPage">[首页]</asp:LinkButton>&nbsp;
                      <asp:LinkButton ID="btnPrev" runat="server" CssClass="link" CommandName="Pager" CommandArgument="Prev" OnCommand ="NavigateToPage">[前一页]</asp:LinkButton>&nbsp;
                      <asp:LinkButton ID="btnNext" runat="server" CssClass="link" CommandName="Pager" CommandArgument="Next" OnCommand="NavigateToPage">[下一页]</asp:LinkButton>&nbsp;
                      <asp:LinkButton ID="btnLast" runat="server" CssClass="link" CommandName="Pager" CommandArgument="Last" OnCommand="NavigateToPage">[尾页]</asp:LinkButton>&nbsp;&nbsp;
                   </div>
                </td>
            </tr>
           </table>
           </div>
       </PagerTemplate>
      <FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
      <PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" />
      <SelectedRowStyle BackColor="#D1DDF1" ForeColor="#333333" Font-Bold="True" />
      <HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
      <AlternatingRowStyle BackColor="White" />
      <RowStyle BackColor="#EFF3FB" />
      <EditRowStyle BackColor="#2461BF" />
    </asp:GridView>

    <asp:Label ID="labmessage" runat="server"></asp:Label>

设计页面截图为:

ASP.NET GridView 自定义分页 - Kingkang - Kingkang的博客

后台代码为:

    protected void GridViewBinding()
    {
        rowcount = ds.Tables[0].Rows.Count;
        gridview1.DataSource = ds;
        gridview1.DataBind();
    }

    protected void NavigateToPage(object sender, CommandEventArgs e)
    {
        switch (e.CommandArgument.ToString())
        {
            case "First":
                this.gridview1.PageIndex = 0;
                break;
            case "Prev":
                if (this.gridview1.PageIndex > 0)
                    this.gridview1.PageIndex -= 1;
                break;
            case "Next":
                if (this.gridview1.PageIndex < (this.gridview1.PageCount - 1))
                    this.gridview1.PageIndex += 1;
                break;
            case "Last":
                this.gridview1.PageIndex = this.gridview1.PageCount - 1;
                break;
        }
        GridViewBinding();
    }

protected void gridview1_DataBound(object sender, EventArgs e)
    {
        if (ds.Tables[0].Rows.Count!=0)
        {
            GridViewRow pagerRow = gridview1.BottomPagerRow;
            gridview1.BottomPagerRow.Visible = true;

            //获取Label实例,显示页次信息
            Label lblCurrent = (Label) pagerRow.Cells[0].FindControl("lblPageCurrent");
            Label lblCount = (Label) pagerRow.Cells[0].FindControl("lblPageCount");
            Label lblRow = (Label) pagerRow.Cells[0].FindControl("lblPageRow");
            //获取按钮实例,为了控制其是否可用
            LinkButton btnFirstTem = (LinkButton) pagerRow.Cells[0].FindControl("btnFirst");
            LinkButton btnPrevTem = (LinkButton) pagerRow.Cells[0].FindControl("btnPrev");
            LinkButton btnNextTem = (LinkButton) pagerRow.Cells[0].FindControl("btnNext");
            LinkButton btnLastTem = (LinkButton) pagerRow.Cells[0].FindControl("btnLast");

            if (lblCurrent != null)
                lblCurrent.Text = (this.gridview1.PageIndex + 1).ToString();
            if (lblCount != null)
                lblCount.Text = this.gridview1.PageCount.ToString();
            if (lblRow != null)
                lblRow.Text = rowcount.ToString();

            if (this.gridview1.PageIndex == 0)
            {
                btnFirstTem.Enabled = false;
                btnPrevTem.Enabled = false;
                //只有一页,所有分页按钮不可用
                if (this.gridview1.PageCount == 1)
                {
                    btnNextTem.Enabled = false;
                    btnLastTem.Enabled = false;
                }
            }
            else if (this.gridview1.PageIndex == (this.gridview1.PageCount - 1))
            {
                btnNextTem.Enabled = false;
                btnLastTem.Enabled = false;
            }
        }
        else
        {
            labmessage.Text = "无相关记录!";
        }
    }

转载于:https://www.cnblogs.com/kangjin0828/archive/2010/03/15/1686573.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是ASP.NET中使用DataGridView进行分页的代码示例: 1.在页面上添加GridView控件和Pager控件: ```html <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"> <Columns> <asp:BoundField DataField="Id" HeaderText="ID" /> <asp:BoundField DataField="Name" HeaderText="Name" /> <asp:BoundField DataField="Age" HeaderText="Age" /> </Columns> </asp:GridView> <asp:Pager ID="Pager1" runat="server" /> ``` 2.在代码中获取数据并绑定到GridView: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { BindGrid(); } } private void BindGrid() { int pageSize = Pager1.PageSize; // 每页显示的记录数 int pageIndex = Pager1.CurrentPageIndex; // 当前页码 // 获取数据并进行分页 List<MyData> list = GetData(); int totalCount = list.Count; int totalPages = (int)Math.Ceiling(totalCount / (double)pageSize); int startIndex = (pageIndex - 1) * pageSize; int endIndex = Math.Min(startIndex + pageSize, totalCount) - 1; List<MyData> data = list.GetRange(startIndex, endIndex - startIndex + 1); // 绑定数据到GridView GridView1.DataSource = data; GridView1.DataBind(); // 设置Pager控件的相关属性 Pager1.RecordCount = totalCount; Pager1.TotalPages = totalPages; } ``` 3.在Pager控件的PageChanged事件中重新绑定GridView: ```csharp protected void Pager1_PageChanged(object sender, EventArgs e) { BindGrid(); } ``` 以上代码中的MyData是自定义的数据类,根据实际情况进行替换。另外,Pager控件需要在代码中设置PageSize和CurrentPageIndex属性的初始值,可以在Page_Load事件中进行设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值