用户控件触发事件

假定用户控件(UserControl.ascx)中包含按钮控件AButton,希望实现按AButton按钮时,包含该用户控件的页面可以接收到事件。为此,在用户控件和页面的代码中分别作了处理。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

UserControl.ascx.cs中的处理:

1. 定义public的事件委托,如ClickEventHandler;
2.
UserControl类中声明事件,如
Click;
3.
UserControl类中定义引发事件的方法,如OnClick()方法
;
4.
UserControl类的相关方法中调用引发事件的方法,如在Button_Click()中调用OnClick()



public delegate void ClickEventHandler(object sender, EventArgs e);

public class MyUserControl : System.Web.UI.UserControl
{
       protected System.Web.UI.WebControls.Button AButton;
       public event ClickEventHandler Click;
       protected void OnClick(EventArgs e)
       {
             if (Click!=null) Click(this, e);
       }
       private void AButton_Click(object sender, System.EventArgs e)
       {
              this.OnClick(e);
       }
}

 

 

包含UserControl的页面cs文件中的处理:

1. InitializeComponent()中增加事件处理程序,采用FindControl方法找到UserControl
2.
定义事件处理方法,在该方法中处理UserControl的事件,如UserControl_Clicked()
核心代码示意如下:
private void InitializeComponent()
{
          this.Load += new System.EventHandler(this.Page_Load);
          MyUserControl uc = this.FindControl("myUserControlID") as MyUserControl;
          uc.Click += new ClickEventHandler(this.UserControl_Clicked);
}
private void UserControl_Clicked(object sender, System.EventArgs e)
{
// UserControl_Clicked event hanlder
}

总结一下,其实就是将事件机制利用手工编程的方法加进去:加入一般控件IDE自动生成的代码。顺便说一下,C#的事件机制实现了Obeserver pattern,除了UI还可以用于业务层,能有效地降低对象间的耦合度,像UserControl那样,根本无需知道包含它的页面对象是谁!



**另一种方法

引用页面:<@Register TagPrefix=”uc1” TagName=”editSearch” src=”…/search/editSearch.ascx”>

后台页面:protected Search.editSearch EditSearch1;

添加事件:this.EditSearch1.onClick = new EnentHander(DgFoot_onClick);

定义事件:private void DgFoot_onClick(object sender,EventAegs e)

         {

                   //执行事件的方法

}

用户控件页面:

定义事件:public event ErentHander onClick;

建立触发事件:if(onClick!=null)

                   onClick(sender,e);

转载于:https://www.cnblogs.com/dygstudio/archive/2006/07/13/449976.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值