Flex4 创建可被取消的默认事件处理器

默认事件处理器用于在组件内部对某些事件进行默认动作相应,这在很多组件里面都是很普
遍的。这样组件可以触发某些事件,默认对触发的事件进行处理,比如在可关闭的TitleWindow
窗口中,我们单击顶部的关闭按钮,TitleWindow内部的默认关闭事件处理器对该事件进行响应,
执行关闭当前窗口的操作。这样存在一种情况,有时候我们需要在关闭窗口前先提示用户将要关
闭窗口,是否继续等类似的提示,如果用户确认需要关闭,那么就关闭,否则不关闭。对于后面
的一种情况,我们需要阻止默认事件处理器的执行。类似的情况同样发生在我们自行开发的一些
Flex组件中,所以有必要讨论一下如何创建一个可被取消的默认事件处理器。
首先,我们要在组件外部自定义对事件的处理器,而且这个处理器的执行优先级要高于默
认的事件处理器。也就是说,组件内部的事件处理器的优先级要低于外部的处理器。对于组件
外部的事件处理器来说,应有某些方法可以阻止默认事件处理器的执行,具体的实现过程有4
个步骤:
1)在组件内部,创建事件时要设置该事件为可被取消,也就是要设置事件的cancelable标
志为true,该标志对应事件构造函数Event()的第三个参数。
2)在组件内部,添加默认事件侦听处理器时要使用EventPriority.DEFAULT_HANDLER优
先级,于是该事件的默认处理器的优先级就低于普通的事件处理器的优先级。
3)在组件外部,在自定义的事件处理器代码中,要调用event.preventDefault()方法来阻止
事件在组件内部的默认事件处理器的执行。
4)在组件内部,默认的事件处理器代码中使用event.isDefaultPrevented()来检测用户是否
阻止了默认事件处理。
在组件的内部,我们定义了一个alarm事件该事件的默认处理器用于处理alarm事件。
package
{
import flash.events.Event;
import mx.controls.Alert;
import mx.core.EventPriority;
import mx.core.UIComponent;
[Event( name="alarm", type="flash.events.Event" )]
public class MyComponent extends UIComponent
{
public function MyComponent()
{
// 为alarm事件添加默认事件侦听。
/**该事件的优先级为:DEFAULT_HANDLER。这是一个低优先级,以使得普通的事件侦听可以
*先执行,从而用户可以通过调用event.preventDefault()来取消事件的默认处理行为。*/
addEventListener("alarm",handleAlarm,false,EventPriority.DEFAULT_HANDLER,true);
}
//一种简单方法,触发一个可被取消的带默认事件处理的事件。
public function triggerAlarm():void
{
/**创建一个新的alarm事件。这里的关键点为构造函数的第3个参数,
*该参数表示该事件可以通过event.preventDefault()来取消。*/
dispatchEvent( new Event("alarm", false, true ) );
}
// "alarm"事件的默认处理
protected function handleAlarm( event:Event ):void
{
// 检测该事件是否被其他的事件侦听器阻止了默认处理行为。
if ( !event.isDefaultPrevented() )
 {
// 事件没有被取消。
Alert.show( "MyComponent内部Alarm事件默认处理,handleAlarm" );
}
}
} // end class
} // end package


一段简单的测试代码,我们定义了一个alarm事件的侦听器,在其内部调用
event.preventDefault()来阻止该事件的默认执行行为。
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical"xmlns:local="*">
<mx:Script>
<![CDATA[
protected function handleAlarm( event:Event ):void
 {
//为了便于演示,在界面上做一个标记来表示是否要阻止默认事件处理的执行。
if ( preventToggle.selected )
 {
trace( "Default behavior is prevented" );
event.preventDefault();
}
else
 {
trace("We didn"t prevent the default behavior, so we"ll
see the alert from MyComponent.");
}
}
]]>
</mx:Script>
<mx:Button label="触发事件" click="myComp.triggerAlarm();" />
<mx:CheckBox id="preventToggle" label="禁止默认行为?" selected="true" />
<local:MyComponent id="myComp" alarm="handleAlarm( event );" />
</mx:Application>

你可能感兴趣的:(Flex)