默认事件处理器用于在组件内部对某些事件进行默认动作相应,这在很多组件里面都是很普
遍的。这样组件可以触发某些事件,默认对触发的事件进行处理,比如在可关闭的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>
分享到:
相关推荐
6. **代码示例**:在ActionScript中,你可以创建一个自定义的TreeItemRenderer类,覆盖`createChildren()`方法来添加Checkbox,并在Checkbox的change事件处理器中更新数据模型。例如: ```actionscript override ...
例如,通过懒加载技术只在需要时加载节点,或者在大量节点被选中或取消选中时批量更新数据。 6. **测试与调试**: 对修改后的Tree控件进行全面的测试,确保所有功能正常工作,没有边界条件问题,如空节点、只有一...
Flex基于ActionScript和MXML,允许开发者创建交互性强、视觉效果丰富的用户界面。本话题聚焦于“flex日历多选”功能,这是一个针对Flex DateField组件的增强,允许用户在日历中选择多个日期,而非仅限于单个日期选择...
这个函数与上一个函数类似,不同之处在于它还添加了对“取消”按钮的支持,并为每个按钮都绑定了事件处理器。 ### 结论 通过以上介绍,我们可以看到,在Flex中定制弹出对话框是一个相对灵活的过程。开发者可以根据...
`Alert.show` 方法接收五个参数:消息文本、对话框标题、按钮类型(例如,3 表示“确定/取消”按钮)、父级组件(本例中为当前应用)以及一个关闭事件处理器。在 `alertClickHandler` 函数中,我们可以根据用户的...
Ubuntu 12.04(代号 Precise Pangolin)是一个长期支持(LTS)版本,发布于2012年,它的默认GCC版本可能是4.x系列,与压缩包中的编译器版本相匹配。 在解压"linux-0.11-060618-gcc4.tar.gz"后,会得到一个名为...
一种是以下划线开头的文件,例如`_variables.scss`,这些文件被称为部分(partials),它们默认不会被编译成独立的CSS文件,而是用于被其他SCSS文件导入。另一种是没有下划线的文件,如`bootstrap.scss`,它们会被...
/* 取消默认轮廓 */ border-color: #4CAF50; } button:hover { background-color: #45a049; } ``` 5. **错误处理**:当用户输入无效数据时,可以使用CSS显示错误提示。例如,添加红色边框或错误消息: ``...
- 可以通过CSS的`display`和`flex`属性来控制布局。 **Document(文档)** - HTML和CSS共同构成的网页文件。 - 可以通过CSS来增强文档的可读性和美观性。 **Father(父元素)** - DOM树中某元素的直接上级元素。 -...