动态加载Asp.net分页控件

动态加载Asp.net分页控件

郑佐 2004-11-30

         asp.net中动态加载控件比较简单,这里我讲得是对用户控件的加载,比较典型的就是被加载的用户控件里面包含回发事件,在回传回来的时候需要保持新的数据。

         先来构建分页用户控件,由于前面几篇文章都在讲这些东西,所以就直接拿过来改了改,分页代码可以查看上面的文章1文章2,下面是用户控件的一部分代码。

public class PagingControl : System.Web.UI.UserControl

{

     private int pageCount;

     private int recordCount;

     ……

     private void Page_Load(object sender, System.EventArgs e)

     {

         if(!Page.IsPostBack)

         {

              DataGridDataBind();

         }

     }

     //绑定数据

     private void DataGridDataBind()

     {

         DataSet ds = GetCustomersData(PageIndex,PageSize,ref recordCount,ref pageCount);

         this.DataGrid1.VirtualItemCount = RecordCount;

         this.DataGrid1.DataSource = ds;

         this.DataGrid1.DataBind();

         SetPagingState();

     }

     //绑定新的页面

private void LBtnNavigation_Click(object sender, System.EventArgs e)

     {

         LinkButton btn = (LinkButton)sender;

         switch(btn.CommandName)

         {

              case "First":

                   PageIndex = 0;

                   break;

              case "Prev":

                   PageIndex = PageIndex - 1;

                   break;

              case "Next":

                   PageIndex = PageIndex + 1;

                   break;

              case "Last":

                   PageIndex = PageCount - 1;

                   break;

         }

         DataGridDataBind();             

     }

……

}

在上面我们注意到在页面Load事件中判断if(!Page.IsPostBack)来防止在回发加载的时候进行两次绑定,因为第一次完全没有必要,最终由LBtnNavigation_Click中的绑定决定。

假设PagingControl.ascx为上面的用户控件的文件名,而且同Page页面文件在同一目录,下面是AspnetCommonPaging.aspx文件的代码,为了动态加载,在页面上放了一个PlaceHolder控件来加载先前的用户控件。

前台文件如下:

<%@ Page language="c#" Codebehind="AspnetCommonPaging.aspx.cs" AutoEventWireup="false" Inherits="AspnetPaging.AspnetCommonPaging" %>

<!DOCTYPE HTML PUBLIC "-//W 3C //DTD HTML 4.0 Transitional//EN" >

<HTML>

  <HEAD>

                   <title>AspnetCommonPaging</title>                  

  </HEAD>

         <body>

                   <form id="Form1" method="post" runat="server">

<asp:PlaceHolder id="PlaceHolder1" runat="server"></asp:PlaceHolder>

                   </form>

         </body>

</HTML>

后台代码文件也比较简单:

namespace AspnetPaging

{

     public class AspnetCommonPaging : System.Web.UI.Page

     {

         protected System.Web.UI.WebControls.PlaceHolder PlaceHolder1;

    

         private void Page_Load(object sender, System.EventArgs e)

         {

              PlaceHolder1.Controls.Add(Page.LoadControl("~/PagingControl.ascx"));

         }

 

         #region Web 窗体设计器生成的代码

         override protected void OnInit(EventArgs e)

         {

              InitializeComponent();

              base.OnInit(e);

         }

        

         /// <summary>

         /// 设计器支持所需的方法 - 不要使用代码编辑器修改

         /// 此方法的内容。

         /// </summary>

         private void InitializeComponent()

         {   

              this.Load += new System.EventHandler(this.Page_Load);

         }

         #endregion

     }

}

 

这里的PlaceHolder1.Controls.Add(Page.LoadControl("~/PagingControl.ascx"));就是把PagingControl用户控件载到当前页面上来。如果不想用PlaceHolder,我们也可以使用其他容器控件,只要添加到Controls集合就行了。

注意这里如果按下面这样处理,那面在页面回发的时候就会不被加载,那么也就不会触发分页事件。

private void Page_Load(object sender, System.EventArgs e)

{

     if(!Page.IsPostBack)

         PlaceHolder1.Controls.Add(Page.LoadControl("~/PagingControl.ascx"));

}

现在让我们来看看主要事件的执行顺序:设置断点,得到下面的顺序。

第一次:页面OnInit事件-->页面Page_Load事件à控件OnInit事件à控件Page_Load事件。

翻页回发:页面OnInit事件-->页面Page_Load事件à控件OnInit事件à控件Page_Load事件à LBtnNavigation_Click翻页事件。

如果我们把页面加载代码放在页面OnInit事件:

override protected void OnInit(EventArgs e)

{

     InitializeComponent();

     PlaceHolder1.Controls.Add(Page.LoadControl("~/PagingControl.ascx"));

     base.OnInit(e);

}

那么事件的执行顺序会是什么样呢?

第一次:页面OnInit事件-->控件OnInit事件à页面Page_Load事件à控件Page_Load事件。

翻页回发:页面OnInit事件-->控件OnInit事件à页面Page_Load事件à控件Page_Load事件à LBtnNavigation_Click翻页事件。

我认为对于多控件的互操作,清楚事件的执行顺序是很重要的,另外也有助于优化程序提高性能。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
再次声明 千万不要把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进制 分页控件详情请看内置文档
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值