分页GRIDVIEW两种分页代码

gridview分页  时间:2021-02-11  阅读:()

第一种分页

A.aspx文件

<%@ Page Language="C#" CodeFile="真分页.aspx.cs" Inherits="_Default" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head runat="server">

<title>自定义代码实现真分页</title>

</head>

<body>

<form id="form1" runat="server">

<div>

<asp:GridView ID="GridView1" runat="server">

</asp:GridView>

<br />

共有记录<asp:Label ID="lblrecordamount" runat="server" BackColor="White"ForeColor="Red"></asp:Label>条&nbsp;每页显示<asp:Label

ID="lblpagesize" runat="server" BackColor="White"ForeColor="Red"></asp:Label>条<br />

共有<asp:Label ID="lblpagecount" runat="server" BackColor="White"

ForeColor="Red"></asp:Label>页&nbsp; 当前是第<asp:Label

ID="lblcurpageindex" runat="server" BackColor="White"ForeColor="Red"></asp:Label>页<br />

<br />

<asp:LinkButton ID="lbFirst" runat="server" CommandName="first"OnCommand="lbLast_Command">首页</asp:LinkButton>&nbsp;

<asp:LinkButton ID="lbPrev" runat="server" CommandName="prev"OnCommand="lbLast_Command">上一页</asp:LinkButton>

&nbsp;

<asp:LinkButton ID="lbNext" runat="server" CommandName="next"OnCommand="lbLast_Command">下一页</asp:LinkButton>&nbsp;

<asp:LinkButton ID="lbLast" runat="server" CommandName="last"OnCommand="lbLast_Command"> 尾 页 </asp:LinkButton>&nbsp; 直 接 跳 转 到<asp:DropDownList

ID="ddl" runat="server"OnSelectedIndexChanged="ddl_SelectedIndexChanged">

</asp:DropDownList>页</div>

</form>

</body>

</html>

A.aspx.cs文件using System;using System.Data;

using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;public partial class _Default : System.Web.UI.Page

{private int recordamount = 0; //表中的记录总数private int pagesieze = 5; //每页显示多少条记录private int pagecount = 0; //共需要分多少页private int curpageindex = 0; //当前是第几页protected void Page_Load(object sender, EventArgs e)

{

//第一次请求该页时初始化recordamount、 pagesieze、 pagecount这3个值这3个值在以后的显示中都不会改变if (!this. IsPostBack)

{

SqlDataSource ds = new SqlDataSource() ;

ds.ConnectionString

= ConfigurationManager.ConnectionStrings["gvdb"] .ConnectionString;ds.SelectCommand = "select count(*) from stuinfo";

DataView dv = (DataView)ds.Select(DataSourceSelectArguments.Empty) ;int count = int.Parse(dv[0] [0] .ToString() ) ;

//初始化表中的记录总数recordamount = count;

//初始化总页数if (recordamount % pagesieze == 0)

{pagecount = recordamount / pagesieze;

}else

{pagecount = recordamount / pagesieze + 1 ;

}

//第一次浏览该页面时显示第一页所以当前页就是第一页curpageindex = 1 ;

//用Label记下这4个变量的值这样这4个变量的值就可以在服务器和浏览器端来回传递而不需要每次显示时都计算一遍this. lblrecordamount.Text = recordamount.ToString() ;

this. lblpagesize.Text = pagesieze.ToString() ;this. lblpagecount.Text = pagecount.ToString() ;this. lblcurpageindex.Text = curpageindex.ToString() ;

//初始化DropDownList1for (int i = 1 ; i <= pagecount; i++)

{this.ddl. Items.Add(i.ToString() ) ;

}

//由于4个参数的值已经确定那么要显示的记录是从几到几就都确定了这时候直接显示就可以了

ShowInfo() ;

}

//与应用程序不同的地方是此处一定要把当前页面的索引值和分页总数的值存储起来 因为//网页跳转过程中跳转入口的不确定性后面随时要用到所以必须单独存储。

//curpageindex、 pagecount这2个值在“首页、上一页、下一页、尾页”这4个按钮的事件中需要使用所以应该在每次加载时都为这2个参数赋值curpageindex = int.Parse(this. lblcurpageindex.Text) ;pagecount = int.Parse(this. lblpagecount.Text) ;

}

//根据4个变量来显示数据的方法

public void ShowInfo()

{

SqlDataSource ds = new SqlDataSource() ;ds.ConnectionString =ConfigurationManager.ConnectionStrings["gvdb"] .ConnectionString;ds.SelectCommand = "proc_stuinfopage";ds.SelectCommandType = SqlDataSourceCommandType.StoredProcedure;

//为存储过程的2个参数赋值int start = pagesieze * (curpageindex - 1) + 1 ;int end = pagesieze * curpageindex;ds.SelectParameters.Add("startindex", start.ToString() ) ;ds.SelectParameters.Add("endindex", end.ToString() ) ;

DataView dv = (DataView)ds.Select(DataSourceSelectArguments.Empty) ;this.GridView1.DataSource = dv;this.GridView1.AutoGenerateColumns = true;this.GridView1.DataBind() ;

//改变当前是第几页这个Label的标签this. lblcurpageindex.Text = curpageindex.ToString() ;

//实现ddl同步this.ddl.SelectedValue = curpageindex.ToString() ;//设置按钮的可用性if (curpageindex == 1)

{this. lbFirst.Enabled = false;this. lbPrev.Enabled = false;

}else

{this. lbPrev.Enabled = true;this. lbFirst.Enabled = true;

}if (curpageindex == pagecount)

{this. lbLast.Enabled = false;this. lbNext.Enabled = false;

}else

{

this. lbNext.Enabled = true;this. lbLast.Enabled = true;

}

}

// “首页、上一页、下一页、尾页”这4个按钮的事件处理程序共用一个事件处理程序protected void lbLast_Command(object sender, CommandEventArgs e)

{if (e.CommandName == "f irst") //首页就是将当前页设为1

{curpageindex = 1 ;

}else if (e.CommandName == "next") //下一页就是当前页+1

{curpageindex++;

}else if (e.CommandName == "prev") //上一页就是当前页-1

{curpageindex--;

}

else if (e.CommandName == "last") //尾页就是当前页=总页数也就是最后一页

{curpageindex = pagecount;

}

//显示数据

ShowInfo() ;

}protected void ddl_SelectedIndexChanged(object sender, EventArgs e)

{string a = this.ddl.SelectedValue;curpageindex = int.Parse(a) ;

ShowInfo() ;

}

}

代码简析看效果图就可以看出这种分页是在GridVi ew外部分页 且其绑定对象是SqlDataSource因此它的分页代码是在GridView外写代码相对叫简单但确定是效果图看上去不是那么美观。其主要实现过程是

1. 实例化4个存储变量 以分别存储表中的记录总数每页显示多少条记录共需要分多少页 当前是第几页

2. 在页面加载时 同步初始化以上4个变量并将其值用相应的label标签显示出来。如此同时初始化DropDownList1 即通过循环把分页总数依次加载到下拉列表种。然后就调用ShowInfo()方法将分页后的信息显示到GridView中。

NameCheap域名转入优惠再次来袭 搜罗今年到期域名续费

在上个月的时候也有记录到 NameCheap 域名注册商有发布域名转入促销活动的,那时候我也有帮助自己和公司的客户通过域名转入到NC服务商这样可以实现省钱续费的目的。上个月续费转入的时候是选择9月和10月份到期的域名,这不还有几个域名年底到期的,正好看到NameCheap商家再次发布转入优惠,所以打算把剩下的还有几个看看一并转入进来。活动截止到9月20日,如果我们需要转入域名的话可以准备起来。 N...

无忧云:服务器100G高防云服务器,bgpBGP云,洛阳BGP云服务器2核2G仅38.4元/月起

无忧云怎么样?无忧云值不值得购买?无忧云,无忧云是一家成立于2017年的老牌商家旗下的服务器销售品牌,现由深圳市云上无忧网络科技有限公司运营,是正规持证IDC/ISP/IRCS商家,主要销售国内、中国香港、国外服务器产品,线路有腾讯云国外线路、自营香港CN2线路等,都是中国大陆直连线路,非常适合免备案建站业务需求和各种负载较高的项目,同时国内服务器也有多个BGP以及高防节点。目前,四川雅安机房,4...

pia云低至20/月,七折美国服务器

Pia云是一家2018的开办的国人商家,原名叫哔哔云,目前整合到了魔方云平台上,商家主要销售VPS服务,采用KVM虚拟架构 ,机房有美国洛杉矶、中国香港和深圳地区,洛杉矶为crea机房,三网回程CN2 GIA,带20G防御,常看我测评的朋友应该知道,一般带防御去程都是骨干线路,香港的线路也是CN2直连大陆,目前商家重新开业,价格非常美丽,性价比较非常高,有需要的朋友可以关注一下。活动方案...

gridview分页为你推荐
云播怎么看片云播看不了视频公章制作如何制作公章唱吧电脑版官方下载唱吧有电脑版的么? 在哪里下载啊?网易公开课怎么下载如何将网易公开课下载到电脑上?蘑菇街美丽说蘑菇街、美丽说这类网站前期是怎么推广的?怎么点亮qq空间图标怎样点亮qq空间的图标ios系统iOS系统为什么那么好小米手柄小米手柄和飞智手柄哪个好?聚美优品红包在支付宝钱包里的聚美优品红包要怎么使用去鼠标加速度win7怎么去鼠标加速度
jsp虚拟主机 域名服务器 国内vps 老域名全部失效请记好新域名 typecho 大容量存储 合肥鹏博士 京东商城0元抢购 微信收钱 宁波服务器 爱奇艺vip免费领取 33456 宏讯 河南移动梦网 韩国代理ip 论坛主机 新加坡空间 广州虚拟主机 广东主机托管 asp介绍 更多