[GridView控件]自定义分页

本文介绍了一种在ASP.NET中使用GridView控件实现自定义分页的方法。通过隐藏字段保存当前页码PageIndex,并利用按钮控制分页逻辑,实现了简单的自定义分页功能。
前些天我写了关于 <<在存储过程中实现分页>>和<<GridView控件事件详解 >>   ,后来又有一些人问我怎样在GridView中应用这个东东!其实很简单,主要是怎么保存当前页面的页码PageIndex问题,不过把这个解决了什么都好办了.因为在分页过程中:PageSize是一定的,我们可以用一个属性来表示.保存PageIndex好多中方法,而且数据不是很庞大,基本不会好太多的资源.还是一句老话,话再多都没有例子直观.

  在这里我们将用一个隐藏字段来保存这个PageIndex,即当前页码.当点击上一页时,将它的值减一,知道为0,要注意的一点这里的第一页页码是0而不是1.下面看看代码,然后我们再分析分析!
 1 None.gif < asp:GridView  ID ="NewsGrid"  runat ="server"  AutoGenerateColumns ="False"  AllowPaging ="false"  Width ="100%" >
 2 None.gif             < Columns >
 3 None.gif                 < asp:BoundField  DataField ="NewsId"  HeaderText ="新闻ID" />
 4 None.gif                 < asp:HyperLinkField  DataNavigateUrlFields ="NewsId"  DataNavigateUrlFormatString ="~/Details.aspx?ID={0}"
 5 None.gif                    DataTextField ="Title"  HeaderText ="新闻标题"   ItemStyle-Width ="70%" />
 6 None.gif                 < asp:BoundField  DataField ="PostTime"  HeaderText ="发布时间" />
 7 None.gif                 < asp:CommandField  HeaderText ="新闻管理"  ShowCancelButton ="False"  ShowDeleteButton ="True"
 8 None.gif                    ShowEditButton ="True" />
 9 None.gif             </ Columns >
10 None.gif         </ asp:GridView >
11 None.gif         < div  style =" height:16px; padding-top:5px; margin-right:30px; float:right" >
12 None.gif         < asp:HiddenField  ID ="CurrentPage"  runat ="server"  Value ="0" />
13 None.gif         < asp:LinkButton  ID ="First"  runat ="server"  CommandArgument ="first"  OnClick ="PagerButton_Click" > 首 页 </ asp:LinkButton >
14 None.gif         < asp:LinkButton  ID ="Prev"  runat ="server"  CommandArgument ="prev"  OnClick ="PagerButton_Click" > 上一页 </ asp:LinkButton >
15 None.gif         < asp:LinkButton  ID ="Next"  runat ="server"  CommandArgument ="next"  OnClick ="PagerButton_Click" > 下一页 </ asp:LinkButton >
16 None.gif         < asp:LinkButton  ID ="Last"  runat ="server"  CommandArgument ="last"  OnClick ="PagerButton_Click" > 尾 页 </ asp:LinkButton >
17 None.gif         </ div >
  CS文件中的代码:
 1 None.gif          protected   void  PagerButton_Click( object  sender, EventArgs e)
 2 ExpandedBlockStart.gif         {
 3InBlock.gif            int pageIndx = Convert.ToInt32(CurrentPage.Value);
 4InBlock.gif            int totals = NewsManager.GetNews(0, pageSize).TotalRecords;
 5InBlock.gif            int pages = (totals % pageSize) == 0 ? (totals / pageSize) : (totals / pageSize + 1);
 6InBlock.gif            string arg = ((LinkButton)sender).CommandArgument.ToString().ToLower();
 7InBlock.gif            switch (arg)
 8ExpandedSubBlockStart.gif            {
 9InBlock.gif                case "prev":
10InBlock.gif                    if (pageIndx > 0)
11ExpandedSubBlockStart.gif                    {
12InBlock.gif                        pageIndx -= 1;
13ExpandedSubBlockEnd.gif                    }
14InBlock.gif                    break;
15InBlock.gif                case "next":
16InBlock.gif                    if (pageIndx < pages - 1)
17ExpandedSubBlockStart.gif                    {
18InBlock.gif                        pageIndx += 1;
19ExpandedSubBlockEnd.gif                    }
20InBlock.gif                    break;
21InBlock.gif                case "last":
22InBlock.gif                    pageIndx = pages - 1;
23InBlock.gif                    break;
24InBlock.gif                default:
25InBlock.gif                    pageIndx = 0;
26InBlock.gif                    break;
27ExpandedSubBlockEnd.gif            }
28InBlock.gif            CurrentPage.Value = pageIndx.ToString();
29InBlock.gif            NewsGrid.DataSource = NewsManager.GetNews(pageIndx , pageSize).Entities;
30InBlock.gif            NewsGrid.DataBind();
31ExpandedBlockEnd.gif        }
  

  是不是很简单啊,看了代码就都懂了,关于用按钮传参数在这里就不多说了,还有一个就是Entities属性,在<<应用实体类EntitySet实现类似的范型功能 >>这篇文章中可以找到!


本文转自网魂小兵博客园博客,原文链接:http://www.cnblogs.com/xdotnet/archive/2006/09/29/gridview_paging_myself.html,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值