asp.net事件委托易理解实例

比如说一个公司(场景),你是老板,手下有两个员工,小张和小王。

你命令小王,如果小张玩游戏,则小王扣去小张500元钱。
这就是现实中的委托。
实际上,在写程序中,程序员就是老板,小张和小王就是两个对象。小张玩游戏是一个方法,小张还有一个游戏事件,他玩游戏激发这个事件。而小王就是事件处理对象,他负责把小张的钱扣除500。
所以,委托有如下几个要素:
1 激发事件的对象--就是小张
2 处理对象事件的对象--就是小王
3 定义委托,就是你让小王监视小张。
如果这三个要素都满足的话,则你就写出了一个完整事件的处理。
下面有个例子:在vs.net2003 C#控制台应用程序编辑运行成功:
using System;
namespace CSharpConsole
{
  public class 场景
  {
    [STAThread]
    public static void Main(string[] args)
    {
      Console.WriteLine("场景开始了....");
      // 生成小王
      小王 w = new 小王();
      // 生成小账
      小张 z = new 小张();

         // 指定监视

      z.PlayGame += new PlayGameHandler(w.扣钱);
      // 开始玩游戏
      z.玩游戏();
      console.writeline("场景结束...");
      Console.ReadLine();
    }
  }

  // 负责扣钱的人
  public class 小王
  {
    public 小王()
    {
      Console.WriteLine("生成小王...");
    }
    public void 扣钱(object sender,EventArgs e)
    {

      Console.WriteLine("小王:好小子,上班时间胆敢玩游戏...");

      Console.WriteLine("小王:看看你小子有多少钱...");
      小张 f = (小张)sender;
      Console.WriteLine("小张的钱: " + f.钱.ToString());
      Console.WriteLine("开始扣钱......");
      System.Threading.Thread.Sleep(500);
      f.钱 = f.钱 - 500;
      Console.WriteLine("扣完了....现在小张还剩下:" + f.钱.ToString());
    }
  }
  // 如果玩游戏,则引发事件
  public class 小张
  {
    // 先定义一个事件,这个事件表示“小张”在玩游戏。
    public event PlayGameHandler PlayGame;
    // 保存小张钱的变量
    private int m_Money;
    public 小张()
    {
      Console.WriteLine("生成小张....");
      m_Money = 10000; // 构造函数,初始化小张的钱。
    }
    public int 钱 // 此属性可以操作小张的钱。
    {
      get
      {
        return m_Money;
      }
      set
      {
        m_Money = value;
      }
    }
    public void 玩游戏()
    {
      Console.WriteLine("小张开始玩游戏了.....");
      Console.WriteLine("小张:CS好玩,哈哈哈! 我玩.....");
      System.Threading.Thread.Sleep(500);
      System.EventArgs e = new EventArgs();
      //OnPlayGame(e);
      if(PlayGame != null)
      {
        PlayGame(this,e);
      }
    }
    protected virtual void OnPlayGame(EventArgs e)
    {
      if(PlayGame != null)
      {
        PlayGame(this,e);
      }
    }
  }
  // 定义委托处理程序
  public delegate void PlayGameHandler(object sender,System.EventArgs e);
}

asp.net事件委托易理解实例

时间: 2024-08-13 20:26:44

asp.net事件委托易理解实例的相关文章

事件冒泡及事件委托的理解(JQuery Dom操作)

jQuery事件冒泡: click mouseenter 等事件没有绑定 也会触发,只是触发后没有任何结果 子元素触发事件后,会把触发事件传递给父元素,那么父元素也会被触发. 不管有没有绑定事件,都会触发事件,只是没有结果,事件冒泡传递还是会发生 系统自动产生的event事件对象 function传的第一个参数就是event事件对象 1 event.stopPropagation(); // 阻止事件冒泡 2 event.preventDefault() // 阻止默认行为 比如submit阻止

深入理解-事件委托

深入理解-事件委托 2016-11-20 15:02javascript.web开发综合.性能优化JS性能优化.事件冒泡.事件委托.事件委托优化.事件委托导致性能损失 65 views 很多人是在使用事件委托的,那对于一个使用者来说,只要能正确的使用好事件委托,完成工作,就算可以了,那么你有认真的考虑过事件委托的原理,以及你的使用场景是否适合使用事件委托呢,如果需要使用事件委托,那么你是否有正确的使用呢?这里我想简单的说一下我对事件委托的理解,希望可以有机会多多交流. 概述 事件委托有哪些好处,

JS事件委托机制简介

目的--为了减少对DOM的操作,使用事件委托. 理解--举例说明:有三个同事预计会在周一收到快递.为签收快递,有两种办法:一是三个人在公司门口等快递:二是委托给前台MM代为签收.现实当中,我们大都采用委托的方案(公司也不会容忍那么多员工站在门口就为了等快递).前台MM收到快递后,她会判断收件人是谁,然后按照收件人的要求签收,甚至代为付款.这种方案还有一个优势,那就是即使公司里来了新员工(不管多少),前台MM也会在收到寄给新员工的快递后核实并代为签收. 原理--事件委托是利用事件的冒泡原理来实现的

c#事件委托

C# 使用委托模型 来实现事件,事件的处理方法不必在将生成事件的类中定义,需要做的事情就是把事件源和事件处理程序结合起来,使用事件处理委托,简称事件委托可以定义为生成事件的类的一个成员,事件委托为多播的. 事件委托的形式 public delegate void MouseHandler(object source , EventArgs e) object souce 为事件源(表示发生事件的来源,比如 button) EventArgs :System.EventArgs类的实例或者派生类的

关于c#中委托与事件的一些理解

文章目的:作者(初学者)在学习c#的过程中,对事件.委托及其中的“object sender,EventArgs e”一直感觉理解不透,因此在网上找了一些资料,学习并整理出了该篇笔记,希望能将自己的心得记录下来作为积累.限于能力且是初学,有错误的地方还请大家批评指正. 注意:该笔记中有部分内容摘自网上的参考资料,并非作者原创,仅限学习交流,特此声明! 一. 委托与事件       委托与事件是一对相互关联的概念.委托是一种引用类型,可通过声明委托变量,并将其初始化为某个匹配的函数来实现对该函数的

jQuery的事件委托实例分析

事件委托主要是利用事件冒泡现象来实现的,对于事件委托的精准的掌握,可以有利于提高代码的执行效率.先看一段代码实例: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>脚本之家</title> <style type="text/css"> table{ width:300px; height:60px; backg

通俗粗暴的事件委托理解

简单粗暴的事件委托理解代码 1 using System; 2 using System.Collections.Generic; 3 4 public class MyClass 5 { 6 public static void RunSnippet() 7 { 8 Header head=new Header(); 9 XiaShuA xiashuaA=new XiaShuA(head); 10 XiaShuB xiashuaB=new XiaShuB(head); 11 head.Rais

理解Javascript中的事件绑定与事件委托

最近在深入实践js中,遇到了一些问题,比如我需要为动态创建的DOM元素绑定事件,那么普通的事件绑定就不行了,于是通过上网查资料了解到事件委托,因此想总结一下js中的事件绑定与事件委托. 事件绑定   最直接的事件绑定:HTML事件处理程序 如下示例代码,通过节点属性显式声明,直接在HTML中,显式地为按钮绑定了click事件,当该按钮有用户点击行为时,便会触发myClickFunc方法. /* html */ <button id="btn" onclick="myCl

理解js事件冒泡事件委托事件捕获

js事件冒泡 javascript的事件传播过程中,当事件在一个元素上出发之后,事件会逐级传播给先辈元素,直到document为止,有的浏览器可能到window为止,这就是事件冒泡现象. <div id="col">    <p>        <a id="btn" href="#">button</a>    </p></div> <script> let b