asp.net分页控件(c#)

分页是web开发中频繁用的模块,今天做了一个分页控件,与大家共享,首先说明以下:

1、此控件利用DataSet分页,没用采用存储过程分页,也许不适合大批量数据分页。

2、 此控件需要结合我上一片文章(“c#操作存储过程的通用封装”)使用。

 

控件前台代码:

<% @ Control Language = " C# "  AutoEventWireup = " true "  CodeFile = " commPage.ascx.cs "  Inherits = " commPage "   %>
< div >
< span > < asp:Label ID = " lblRecordCount "  runat = " server " ></ asp:Label > </ span >   < span > 当前 < asp:Label
    ID
= " lblCurrentPage "  runat = " server "   />/< asp:Label ID = " lblPageCount "  runat = " server "
        Text
= " Label "   /> & nbsp; </ span >   < span  class = " bia " >
            
< asp:LinkButton ID = " lbnPrevPage "  runat = " server "  CommandName = " prev "  OnCommand = " Page_OnClick " > 上一页 </ asp:LinkButton ></ span >
& nbsp; & nbsp; & nbsp; & nbsp; & nbsp; & nbsp; < span  class = " bia " >< asp:LinkButton ID = " lbnNextPage "

    runat="server" CommandName="next" OnCommand="Page_OnClick">下一页</asp:LinkButton></span></div> 

控件后台代码:

  1  using  System;
  2  using  System.Collections;
  3  using  System.Configuration;
  4  using  System.Data;
  5  using  System.Linq;
  6  using  System.Web;
  7  using  System.Web.Security;
  8  using  System.Web.UI;
  9  using  System.Web.UI.HtmlControls;
 10  using  System.Web.UI.WebControls;
 11  using  System.Web.UI.WebControls.WebParts;
 12  using  System.Xml.Linq;
 13  using  mjqDb  =  mjq.zy5777.com;
 14  using  System.Data.SqlClient;
 15 
 16  public   partial   class  commPage : System.Web.UI.UserControl
 17  {
 18       // 查询分页数据总数的存储过程名称
 19       private   string  totalNumProc;
 20 
 21       public   string  TotalNumProc
 22      {
 23           get  {  return  totalNumProc; }
 24           set  { totalNumProc  =  value; }
 25      }
 26       // 查询分页数据的存储过程名称
 27       private   string  selectProc;
 28 
 29       public   string  SelectProc
 30      {
 31           get  {  return  selectProc; }
 32           set  { selectProc  =  value; }
 33      }
 34 
 35       // 绑定数据的控件
 36       private  DataList bindControl;
 37 
 38       public  DataList BindControl
 39      {
 40           get  {  return  bindControl; }
 41           set  { bindControl  =  value; }
 42      }
 43 
 44       private   int  pageSize;
 45 
 46       public   int  PageSize
 47      {
 48           get  {  return  pageSize; }
 49           set  { pageSize  =  value; }
 50      }
 51 
 52       // 查询分页数据总数的存储过程参数
 53       private  SqlParameter[] totalParameters;
 54 
 55       public  SqlParameter[] Parameters
 56      {
 57           get  {  return  totalParameters; }
 58           set  { totalParameters  =  value; }
 59      }
 60       // 查询分页数据的存储过程参数
 61       private  SqlParameter[] selectParameters;
 62 
 63       public  SqlParameter[] SelectParameters
 64      {
 65           get  {  return  selectParameters; }
 66           set  { selectParameters  =  value; }
 67      }
 68       int  RecordCount, PageCount, CurrentPage;
 69      SqlConnection conn;
 70      SqlCommand cmd;
 71       protected   void  Page_Load( object  sender, EventArgs e)
 72      {
 73 
 74           // 判断是不是第一次请求
 75           if  ( ! Page.IsPostBack)
 76          {
 77              ListBind();
 78              CurrentPage  =   0 ;
 79              ViewState[ " PageIndex " =   0 ;
 80 
 81               // 计算总共有多少条记录
 82              RecordCount  =  CalculateRecord();
 83              lblRecordCount.Text  =  RecordCount.ToString();
 84 
 85               // 计算总共多少页
 86              PageCount  =  RecordCount  /  PageSize;
 87              lblPageCount.Text  =  PageCount.ToString();
 88              ViewState[ " PageCount " =  PageCount;
 89 
 90          }
 91      }
 92       // 计算总页数
 93       public   int  CalculateRecord()
 94      {
 95           int  intCount;
 96           string  strCount  =  TotalNumProc;
 97          SqlDataAdapter adpt  =  mjqDb.execStoreProce.createAdpt(totalNumProc,  ref  cmd,  ref  conn, Parameters);
 98          DataSet dsC  =   new  DataSet();
 99          adpt.Fill(dsC);
100           // SqlCommand sqlcmd = new SqlCommand(strCount, sqlcon);
101           // SqlDataReader sdr = sqlcmd.ExecuteReader();
102          DataRow drC  =  dsC.Tables[ 0 ].Rows[ 0 ];
103           if  (Convert.ToInt32(drC[ 0 ])  >   0 )
104          {
105              intCount  =  Convert.ToInt32(drC[ 0 ]);
106          }
107           else
108          {
109              intCount  =   0 ;
110          }
111          adpt.Dispose();
112          dsC.Dispose();
113          cmd.Dispose();
114          conn.Close();
115           return  intCount;
116      }
117      ICollection CreateSource()   // 分页数据集合
118      {
119           int  StartIndex;
120 
121           // 设定导入的起终地址
122          StartIndex  =  CurrentPage  *  PageSize;
123           string  strSel  =  SelectProc;
124          DataSet ds  =   new  DataSet();
125          SqlDataAdapter sda  =  mjqDb.execStoreProce.createAdpt(SelectProc,  ref  cmd,  ref  conn, SelectParameters);
126          sda.Fill(ds, StartIndex, PageSize,  " jixie " ); // 该句表示将数据源中从StartIndex位置取出PageSize条记录导入DataSet.
127           return  ds.Tables[ " jixie " ].DefaultView;
128          
129          ds.Dispose();
130          cmd.Dispose();
131          conn.Close();
132      }
133       // 数据绑定
134       public   virtual   void  ListBind()
135      {
136          BindControl.DataSource  =  CreateSource();
137          BindControl.DataBind();
138          lbnNextPage.Enabled  =   true ;
139          lbnPrevPage.Enabled  =   true ;
140           if  (CurrentPage  ==  (PageCount  -   1 )) lbnNextPage.Enabled  =   false ;
141           if  (CurrentPage  ==   0 ) lbnPrevPage.Enabled  =   false ;
142          lblCurrentPage.Text  =  (CurrentPage  +   1 ).ToString();
143      }
144 
145       // 上下页
146       public   void  Page_OnClick(Object sender, CommandEventArgs e)
147      {
148          CurrentPage  =  ( int )ViewState[ " PageIndex " ];
149          PageCount  =  ( int )ViewState[ " PageCount " ];
150           string  cmd  =  e.CommandName;
151           // 判断cmd,以判定翻页方向
152           switch  (cmd)
153          {
154               case   " next " :
155                   if  (CurrentPage  <  (PageCount  -   1 )) CurrentPage ++ ;
156                   break ;
157               case   " prev " :
158                   if  (CurrentPage  >   0 ) CurrentPage -- ;
159                   break ;
160          }
161          ViewState[ " PageIndex " =  CurrentPage;
162          ListBind();
163      }
164  }

165  

调用:

<% @ Register Src = " commPage.ascx "  TagName = " commPage "  TagPrefix = " uc1 "   %>
<! 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:DataList ID = " dataList "  runat = " server " >
            
< ItemTemplate >
                
< div >
                    
<% #Eval( " title " %>
                
</ div >
            
</ ItemTemplate >
        
</ asp:DataList >
    
</ div >
    
< div >
        
< uc1:commPage ID = " commPage1 "  runat = " server "    />
    
</ div >
    
</ form >
</ body >

</html> 

在调用页的后台 page_load函数中设置属性:

 1  using  System;
 2  using  System.Collections;
 3  using  System.Configuration;
 4  using  System.Data;
 5  using  System.Linq;
 6  using  System.Web;
 7  using  System.Web.Security;
 8  using  System.Web.UI;
 9  using  System.Web.UI.HtmlControls;
10  using  System.Web.UI.WebControls;
11  using  System.Web.UI.WebControls.WebParts;
12  using  System.Xml.Linq;
13  using  mjqDb  =  mjq.zy5777.com;
14  using  System.Data.SqlClient;
15 
16  public   partial   class  _Default : System.Web.UI.Page
17  {
18       protected   void  Page_Load( object  sender, EventArgs e)
19      {
20          commPage1.TotalNumProc  =   " totalProc " ;
21          commPage1.SelectProc  =   " selectProc " ;
22          commPage1.PageSize  =   5 ;
23          commPage1.BindControl  =  dataList;
24      }
25  }

26  

转载于:https://www.cnblogs.com/majiangquan/archive/2009/04/20/1439832.html

再次声明 千万不要把XiaoQi.dll 跟 XiaoQi.XML 给分开 2013年3月8号 修复了很多bug 调整了源代码 添加的时候 一定要引用 不要直接复制DLL 不然没有方法注释 最强大分分页控件 华丽的分页控件 实用的分页控件 有最新最实用的方法 联系小柒 下面是 AspNetHelp 类 方法概述 ///Show()弹出对话框 ///重载Show()弹出对话框 并且跳转界面 ///ShowJavascript()执行javascript脚本 ///FileDelete()给出文件虚拟路径删除文件 ///FileSize()获取上传文件大小 ///FileUpload()文件上传 路径upload/ 自动重命名 ///FileDownload()文件下载 调用方法如 FileDownload(Response,Server,文件虚拟路径) ///FileTxtWrite()写入TXT文本 给出要创建Txt 文本的地址 ///FileTxtReader()读取TXT文本 Txt 文本的地址 返回一个数组 每一行为数组里的一个元素 ///StringEncrypt() DES字符串加密中文不可以加密 ///StringDecrypt()DES解密字符串 ///StringMD5Encrypt()MD5加密 ///StringPYChar()单个汉字返回该汉字首字母 ///StringRandom()生成指定位数的随机数 ///StringEdit()给出指定字符串长度多少位后用点显示... ///StringReplaceSpace()替换文本中的空格和换行 ///StringColor()改变字的颜色 ///StringNull()当对象是空的时候 转为空字符串 ///StringConvert()汉字转拼音 ///StringNumber()数字转换中文 ///StringRep()url参数为中文时候转换加密 ///StringRes()url参数为中文时候转换解密 ///ShowWindowForm()弹出新窗口页面 ///ShowFormModalDialog()弹出模式窗口页面 ///SqlGetMaxID()给出表名列名 int类型 查询出最大列值+1 适用于主键 ///SqlGetSingle()执行一条计算查询结果语句,返回查询结果(object)。 ///SqlExecute()执行SQL语句,返回影响的记录数 ///SqlRunStr()执行SQL语句,不返回影响的记录数 ///SqlRunReturn()执行SQL语句,并返回第一行第一列结果 ///SqlGetReader()获得SqlDataReader对象 使用完须关闭DataReader,关闭数据库连接 ///SqlGetTable()执行查询语句,返回DataTable ///SqlDataSet()执行查询语句,返回DataSet ///SqlIsCunZai()执行Sql 语句查询是否有数据 如果没有返回假 ///SqlRunProc()执行存储过程 ///DataBindDropDownListDefault()DropDownList控件绑定 带默认选择项 如"请选择" ///DataBindDropDownList()DropDownList控件绑定 不带默认选择项 ///DataBindRadioButtonList()RadioButtonList控件绑定 默认第一个选中 ///DataBindCheckBoxList()CheckBoxList控件绑定 ///ElseIpAddr()调用此方法 返回当前登录的省市IP地址 ///ElseDataTimeIng()返回本地电脑的当前日期的年月日时分秒 动态的显示 JS实现 ///ElsePageLoad()页面加载数据加载完成呈现页面 ///ElseCkeck()返回页面验证码图片 使用方法:单独创建一个页面 在首次加载事件里写 AspNetHelp.ElseCkeck(Page); 在使用验证码的页面直接写 img src="这个页面的路径" 注意验证码保存在 Session["CheckCode"]中 这里是区分大小写的 ///ElseColorRGB()由于QQ截图的取色会出现RGB的颜色 这里能转换成16进制 分页控件详情请看内置文档
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值