什么是事件注册?

this.button1.Click += new System.EventHandler(this.button1_Click);

这段代码,实际上也就是所谓的事件注册代码。该代码的意思是:如果this.button1的Click事件发生之后,就转向this. button1_Click方法进行处理。

为了更好的理解事件的注册过程,我们把代码进行修改,将原来的

this.button1.Click += new System.EventHandler(this.button1_Click);

修改为

this.button1.Click = new System.EventHandler(this.button1_Click);

在这个程序里,这里的修改是为了更好理解,当然这种写法是语法错误的。

下面我们对其进行分析:

首先,观察“=”右面的表达式。

new System.EventHandler(this.button1_Click);

大家可以发现,这段代码实际上是建立了一个委托类型的实例,并让该委托指向了this.button1_Click方法。也就是说,在程序运行的“某一时刻”,系统会通过这个委托实例间接的调用this.button1_Click方法。

然后,我们再来观察“=”左面的表达示。在C风格的语言中“=”是赋值表达式,也就是说,“=”两侧表达式的数据类型应该是一样的。因此,既然“=”右侧的表达式是一个委托类型(System.EventHandler)的实例,那么this.button1.Click也应该是一个委托类型(System.EventHandler)。

通过上面的说明,我们得到一个信息,前面这段事件注册代码,是让this.button1.Click和System.EventHandler(this.button1_Click)指向了同一段内存空间,简单来讲,就是让this.button1.Click指向了this.button1_Click方法,调用了this.button1.Click,就相当于调用了this.button1_Click方法。因此,我们说,当this.button1的Click事件发生之后,方法this.button1_Click就会被调用。

在程序运行的时候,系统会自己检测this.button1是否被点击了,如果被点击了,就在button1的内部调用button1.Click,这时,Windows窗口中的button1_Click方法就会被执行。

当然,事件注册代码完全可以手写。因为,除了控件中事件注册代码是自动生成以外,其他类中的事件注册都是手写的。手工注册事件的方法如下:

首先,可以在事件发生之前的任何代码中添加事件(通常是在窗口的构造方法中),下面我们来手工注册button1的MouseMove事件,如下图所示:

当我们写完“=”时,会出现一个提示“Press TAB to insert”,这时,我们只需要按2下“TAB”键,事件的注册以及用于回调的方法,就会自己添加到代码窗口里。

自动生成的代码是将this.button1的MouseMove事件指向了button1_MouseMove方法。这样手写的代码和IDE自动生成的代码是完全一样的。

当然,作为控件的事件,我们完全可以自动生成,如果想自动生成button1的其他事件,只需要查看button1的属性窗口,并点击“”按钮,就会出现该控件的事件列表。

然后双击你想要的事件,代码就会自动生成了。

在前的面代码中为了更好理解事件注册,我们曾将

this.button1.Click += new System.EventHandler(this.button1_Click);

修改为

this.button1.Click = new System.EventHandler(this.button1_Click);

我们会发现,无论是自己写的事件注册代码,还是自动生成的代码,都是使用“+=”来实现的,实际上,作为事件注册的代码,我们仅仅能够使用“+=”来实现注册,简单的使用“=”是语法错误的!!!

“+=”操作符在C风格语言中是常用的操作符,比如

int i=0;

i+=1;

等同于

int i=0;

i=i+1;

因此,

this.button1.Click += new System.EventHandler(this.button1_Click);

在原则上等同于

this.button1.Click = this.button1.Click +

new System.EventHandler(this.button1_Click);

用自然语言来描述上面的代码就是“一个委托=这个委托本身+另外一个委托”。那么委托相加意味着什么呢?

我们讨论过MultiDelegate(多播委托),而事件本身也是委托,并且所有委托都是System.MultiDelegate类的派生类,我们曾经演示过,多个委托类型实例相加,就是将这些委托实例存放在一个多播委托的调用链中,当调用多播委托时,该多播委托的调用链中的所有委托都会顺序的被调用。

利用多播委托的原理,我们可以将多个方法注册给一个事件,如下所示:

this.button1.Click +=new System.EventHandler(this.button1_Click);

this.button1.Click +=new System.EventHandler(this.button1_Click1);

this.button1.Click +=new System.EventHandler(this.button1_Click2);

上面的代码,就将三个方法注册到了button1的Click事件中,当button1的Click事件触发之后,方法button1_Click,button1_Click1,button1_Click2将会被顺序调用。这样作的好处是,我们可以将多个功能以及逻辑完全独立的操作放在不同的方法中,当事件发生之后,这些方法将会顺序的被调用,以实现我的需要的级联操作。

控件中事件的回调方法

说完了事件的注册,下面我们来谈一下事件的回调方法。首先,我们还要再一次回顾事件注册的代码:

this.button1.Click +=new System.EventHandler(this.button1_Click);

上面代码中,使用“new System.EventHandler(this.button1_Click)”将一个System.EventHandler委托类型的实例指向了this.button1_Click方法。我们知道,如果想让一个委托指向一个方法,那么该委托以及所被指向的方法一定要具备相同的签名(Signature,具备相同的参数列表,相同的返回值)。因此,System.EventHandler类型和this.button1_Click方法具备相同的签名,下面,我们来看一下System.EventHandler委托的签名是什么样的:

public delegate void EventHandler(Object sender,EventArgs e)

System.EventHandler的签名是:返回值为void;有两个参数,Object sender, EventArgs e。因此button1_Click方法也具备相同形式,代码如下:

private void button1_Click(object sender, EventArgs e)

{

}

实际上,我们所能够看到的事件回调方法的签名基本上都着不多,只不过第二个参数略有区别,下面,我们对该方法的参数进行说明。

Object sender

从该参数的命名上,可以看出其作用,sender(发送者)的意思是:谁触发的这个事件,那么sender就是谁,由于所有的类型在理论上讲都可以包括事件,因此sender的类型被定义成Object类型,当多个事件同时指向一个事件回调方法的时候,通过该参数可以区分出是哪一个类触发的事件,以便做出不同的处理,此时,需要对参数sender作出类型转化。

l 案例操作:多个事件指向同一个回调方法

首先,添加三个Button,一个TextBox

界面如下:

然后,在主窗口中添加一个方法ButtonClick,这三个按钮的Click事件将调用该方法。

代码如下:

protected void ButtonClick(object sender, EventArgs e)

{

Button bt = sender as Button;

this.textBox1.Text ="我是:"+ bt.Text;

}

上面代码中,为了知道点击的是哪个按钮,我们将sender转化成了Button类型。

下面来指定这三个按钮的Click事件回调方法

首先,切换到button1的属性窗口(F4),点击“”按钮,找到“Click”事件,并设置所调用的方法名为ButtonClick,如下图所示。

然后,以相同的方法设置button2,button3的Click事件,并它们都指向ButtonClick方法。

最后,运行程序,下面是运行情况:

点击button1:

时间: 2024-10-10 10:58:58

什么是事件注册?的相关文章

jQuery 事件注册和绑定及this与event.target的区别浅析

最近小码哥,在研究学习nodejs以及相关框架webpack.express.reactjs等等,为了将来,为了RMB,小码哥牢记自我充电,以备不时之需. 在学习reactjs的时候,在前辈ruanyifeng的博文里看到了一个以前没怎么注意的知识点.是与this和event.target之间的区别有关的.当时感觉就蒙了,发现event.target貌似印象不深啊,,瞬间小码哥开启了奔跑模式,,, 各种baidu,各种Chrome biying等等,发现区分不难,就是比较细致.不细分析,有点晕!

。。。事件注册方法之五。。。

在MainActivity.java文件中,定义另外一个自定义的类: 在MainActivity.java中定义控件对象: 然后通过定义自定义类的对象,将事件对象传入到事件方法中: 通过将MainActivity类中获取得到的控件对象,传入到自定义类中去,然后在自定义类侦中去实现onClick()方法,最后在事件注册函数中,new一个自定义类的对象即可. 其本质还是要传入实现了OnClickListener接口的对象!!!

js事件注册失败问题

昨天开发的时候一直纠结一个问题,给a标签注册事件,却一直没有注册上! $('#myTab li a').click(function() { localStorage.setItem(tabId, $(this).attr("href")); }); 完全是一个普通的事件注册代码.今天排查的结论是,$('#myTab li a')这个元素是ajax异步加载的.而我在ajax的代码调用完毕之后,立刻注册事件.那么问题来了,ajax代码是异步执行的,代码调用完了,不代表需要绑定事件的那个元

Cocos2d-x3.X版本事件注册方法

Cocos2d-x3.X版本事件注册方法: auto listener = EventListenerTouchOneByOne::create(); listener->onTouchBegan = CC_CALLBACK_2(ChartDemoScene::onTouchBegan,this); Director::getInstance()->getEventDispatcher()->addEventListenerWithSceneGraphPriority(listener,

Ms和W3c中事件注册中的this问题

Ms中的事件注册: 1 ele.attachEvent('on' + type, fnHandler) W3c中事件注册: 1 ele.addEventListener(type, fnHandler, false) ?有时我们要在事件注册的函数引用里,引用调用该事件监听器的当前对象 如果是W3c可以直接用this,形如: 1 2 3 function fnHandler(){     console.log(this); } fnHandler中的this就相当于ele了 但是在IE中是不行的

鼠标及事件注册(丫头,加油 ^_^)

鼠标触发事件有以下几种 鼠标控制光标移动到目标元素上的那一刻, 首先触发mouseover 之后如果光标继续在元素上移动,则不断触发mousemove 如果按下鼠标上的设备(左键,右键,滚轮--), 则触发mousedown 当设备弹起的时候触发mouseup 目标元素的滚动条发生移动时(滚动滚轮/拖动滚动条..)触发scroll 滚动滚轮触发mousewheel,注意这个要区别于scroll 鼠标移出元素的那一刻,触发mouseout 事件注册 了解事件注册最好先初步了解下 html DOM

libevent (三) 事件注册与循环监听

事件注册与循环监听 在libevent中为了监听某种事件的发生,设置事件触发后的回调函数,也就是说对该事件注册到当前的IO模型中. 事件注册 事件初始化 使用`event_new`函数来对事件进行初始化. typedef void (*event_callback_fn)(evutil_socket_t, short, void *);/* 回调函数 */ struct event *event_new(struct event_base *base, evutil_socket_t fd, s

事件注册 DOM事件流 事件对象(常用属性,方法) 事件委派(鼠标,键盘事件对象)

注册事件概述 给元素添加事件,称为注册事件或者绑定事件 注册事件有两种方式:传统方式和方法监听注册方式 传统注册方式:利用 on 开头的事件:例如:onclick:注册事件的唯一性,后面的注册事件会把前面的覆盖 方法监听注册方式:addEventListener()IE9+:IE9以前用 attacthEvent()代替:会按照注册顺序依次执行没有唯一性的问题 addEventListener() 事件监听方式 eventTarget.addEventListener(type, listene

jquery 事件注册 与重复事件处理

<!doctype html> <html lang="us"> <head> <meta charset="utf-8"> <title> test</title> <script src="./jquery-1.10.2.js" type="text/javascript"></script> <script> fu