使用委托在用户自定义控件中实现事件响应

假定用户控件(UserControl.ascx)中包含按钮控件AButton,希望实现按AButton按钮时,包含该用户控件的页面可以接收到事件。为此,在用户控件和页面的代码中分别作了处理。

 


        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
     }

posted @   郑文亮  阅读(433)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
历史上的今天:
2011-04-09 QA是什么样的工作(转载)
2011-04-09 QA定义
2011-04-09 web分页打印
2011-04-09 ASP.NET MVC 3里面客户端输入验证的改动 (转)
2011-04-09 asp.net 打印控件使用方法(转) http://www.jb51.net/article/21861.htm
2011-04-09 asp.net 调用打印机 (转)
2011-04-09 asp.net web实现页面部分打印(转)
点击右上角即可分享
微信分享提示