target和currentTarget的区别

本文通过实例解析Flex框架中target与currentTarget的区别,包括它们各自的作用、使用场景及示例代码。
target和currentTarget的区别

开始学习Flex,会在别人的代码中经常看到target和currentTarget这两个属性,一般是event.target、event.currentTarget,那他们两个有什么区别呢?

简单说,target是事件的调用对象(event dispatcher),currentTarget是事件的处理对象(event processor)

[size=large][b][color=red]个人心得:[/color][/b][/size]

可以认为currentTarget是事件的监听者,如果两个组建同时对一个事件进行了监听,则处理从上层到下层顺序依次执行;同级时,按监听添加顺序执行。
一般,target是currentTarget指向的对象(组件)自身或者其子类。

[b][size=large][color=red]转一例子:[/color][/size][/b]

 <?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical" name="app"
initialize="init()">

<mx:Button id="btn" name="btn" label="按钮1"/>

<mx:Button id="btn2" name="btn2" label="按钮2" click="clickHandler(event)" />

<mx:Script>
<![CDATA[
import mx.controls.Alert;
private function init(): void
{
addEventListener(MouseEvent.CLICK, clickHandler);
}

private function clickHandler(event: MouseEvent): void
{
Alert.show("target: " + (event.target as DisplayObject).name
+ "\ncurrentTarget: " + (event.currentTarget as DisplayObject).name);
}
]]>
</mx:Script>
</mx:Application>



解释:


1、点击btn,btn是事件发送者,因此,target是btn;

2、app注册了事件监听器,用于监听MouseEvnet.Click事件,是事件处理者,因此currentTarget是app

3、btn2自己注册了click事件,那么btn2既是事件发送者,又是处理者,因此,target和currentTarget都是btn2,这种情况下,两者是一致的

4、同时注意,由于app注册了鼠标点击事件,在点击btn2的时候,首先响应的是app的处理器,然后才是btn2的处理器
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值