asp.net gridview 自定义分页

下面是aspx的相关代码

  1. <td >
  2.        共 <asp:Label ID="recordCount" runat="server"></asp:Label> 条 
  3.         <asp:Label  ID="LabelCurrentPage" runat="server"></asp:Label>
  4. /
  5. <asp:Label ID="LabelPageCount" runat="server"></asp:Label>页
  6.   </td>
  1. <td>
  2.    <asp:LinkButton ID="First" runat="server" CommandArgument="First" CommandName="Page" 
  3.     OnClick="PagerButton_Click"><font face="Webdings">9</font></asp:LinkButton>
  4.    <asp:LinkButton ID="Prev" runat="server" CommandArgument="Prev" CommandName="Page"
  5.     OnClick="PagerButton_Click"><font face="Webdings">7</font></asp:LinkButton>
  6.    <asp:LinkButton ID="Next" runat="server" CommandArgument="Next" CommandName="Page" 
  7.    OnClick="PagerButton_Click"><font face="Webdings">8</font></asp:LinkButton>
  8.    <asp:LinkButton ID="Last" runat="server" CommandArgument="Last" CommandName="Page" 
  9.    OnClick="PagerButton_Click"><font face="Webdings">:</font></asp:LinkButton>
  10. </td>

下面是cs代码:

在初始化gridview的方法中加入:

  1.         this.First.CommandName = "1";
  2.         this.Prev.CommandName = this.GridView1.PageIndex == 0 ? "1" : this.GridView1.PageIndex.ToString();
  3.         if (this.GridView1.PageCount == 1)
  4.         {
  5.             this.Next.CommandName = this.GridView1.PageCount.ToString();
  6.         }
  7.         else
  8.         {
  9.             int temp = this.GridView1.PageIndex + 2;
  10.             this.Next.CommandName = temp.ToString();
  11.         }
  12.         this.Last.CommandName = this.GridView1.PageCount.ToString();
  13.         this.recordCount.Text = ds.Tables[0].Rows.Count.ToString();
  14.         int t = this.GridView1.PageIndex+1;
  15.         this.LabelCurrentPage.Text = t.ToString();
  16.         this.LabelPageCount.Text = this.GridView1.PageCount.ToString();

按钮单击事件代码:

  1.     protected void PagerButton_Click(object sender, EventArgs e)
  2.     {
  3.         this.GridView1.PageIndex = Convert.ToInt32(((LinkButton)sender).CommandName) - 1;
  4.         init();
  5.     }

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值