当前位置: 首页 > 图文教程 > 网络编程 > ASP > 亲密接触ASP.Net(14)

ASP
ASP调用ORACLE存储过程并返回结果集
用ASP实现网页BBS
关于Global.asa文件的深入研究与session变量失效提示的具体方法
简易ASP+注册系统
防护手册:如何防止ASP木马在服务器上运行
用Visual Basic实现多画面播放功能之二
如何增强ASP程序性能(1)
如何增强ASP程序性能(2)
如何增强ASP程序性能(3)
ASP备份数据库
二十八条改善 ASP 性能和外观的技巧
在Form域中Post大于100K的数据
如何使用ASP制作模似动态生长的表单?
Microsoft IIS 真的如此「不安全」吗?(1)
Microsoft IIS 真的如此「不安全」吗?(2)
Microsoft IIS 真的如此「不安全」吗?(3)
Microsoft IIS 真的如此「不安全」吗?(4)
Microsoft IIS 真的如此「不安全」吗?(5)
关于页面和代码分离
ServerVariables 对路径的操作

亲密接触ASP.Net(14)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 40 ::
收藏到网摘: n/a

       个性化分页(2)
  
  上一节大家没有看到总的结构,这一节,我把代码全部贴出来,大家好好看看。
  
  <%@ Page Language="C#" %>
  <%@ Import Namespace="System.Data" %>
  <%@ Import Namespace="System.Data.SQL" %>
  <html>
  <script language="C#" runat="server">
  
  void Page_Load(Object sender, EventArgs e)
  {
   //判断是否隐藏PagerStyle-Mode
   if (chk1.Checked)
   {
   MyDataGrid.PagerStyle.Visible=true;
   }
   else
   {
   MyDataGrid.PagerStyle.Visible=false;
   }
  
   BindGrid();
  }
  
  ICollection CreateDataSource()
  {
   /*
   读取数据库的信息,获得DataView
   */
   SQLConnection MyConnection = new SQLConnection("server=localhost;uid=sa;pwd=123456;database=aspcn");
   SQLDataSetCommand MyDataSetCommand = new SQLDataSetCommand("select * from admin_enter order by Enter_Time desc",MyConnection);
   DataSet ds= new DataSet();
   MyDataSetCommand.FillDataSet(ds,"admin_enter");
   return ds.Tables["admin_enter"].DefaultView;
  }
  
  void PagerButtonClick(Object sender, EventArgs e)
  {
   //获得LinkButton的参数值
   String arg = ((LinkButton)sender).CommandArgument;
  
   switch(arg)
   {
   case ("next"):
   if (MyDataGrid.CurrentPageIndex < (MyDataGrid.PageCount - 1))
   MyDataGrid.CurrentPageIndex ++;
   break;
   case ("prev"):
   if (MyDataGrid.CurrentPageIndex > 0)
   MyDataGrid.CurrentPageIndex --;
   break;
   case ("last"):
   MyDataGrid.CurrentPageIndex = (MyDataGrid.PageCount - 1);
   break;
   default:
   //本页值
   MyDataGrid.CurrentPageIndex = arg.ToInt32();
   break;
   }
   BindGrid();
  }
  
  void MyDataGrid_Page(Object sender, DataGridPageChangedEventArgs e)
  {
   //处理按下数字的方法
   BindGrid();
  }
  
  void BindGrid()
  {
   //将DataView绑定到DataGrid上去
   MyDataGrid.DataSource = CreateDataSource();
   MyDataGrid.DataBind();
   ShowStats();
  }
  
  void ShowStats()
  {
   //显示页面信息
   lblCurrentIndex.Text = "当前页数为: " + ((int)MyDataGrid.CurrentPageIndex+1);
   lblPageCount.Text = "总页数是: " + MyDataGrid.PageCount;
  }
  
  </script>
  
  <body>
  
  <h3><font face="Verdana">个性化的分页实例^&^</font></h3>
  
  <form runat=server>
  
  <ASP:DataGrid id="MyDataGrid" runat="server"
  AllowPaging="True"
  PageSize="10"
  PagerStyle-Mode="NumericPages"
  PagerStyle-HorizontalAlign="Right"
  OnPageIndexChanged="MyDataGrid_Page"
  BorderColor="black"
  BorderWidth="1"
  GridLines="Both"
  CellPadding="3"
  CellSpacing="0"
  Font-N