加载模块简单来说有2种方式,一种是较为简单的使用ModuleLoader,另一种是使用ModuleManager。
ModuleManager类提供了低层次的处理Module的装载卸载以及事件响应等的变成接口。这种方式比起纯粹的ModuleLoader方式稍微复杂一点,但是ModuleManager提供了比ModuleLoader更加强大的能力来管理Module模块的加载过程。
ModuleManager类负责管理加载的模块。当public的ModuleLoader.loadModule和ModuleLoader.unloadModule方法被调用时,组件其实在内部与这个管理器进行通信。你可以用ActionScript直接访问ModuleManager管理的那些模块。当将模块的URL传递到public的ModuleManager.getModule方法中时,则该模块位置就被添加到被管理模块列表中,并返回一个mx.modules.IModuleInfo的实例。
模块本质上就是ModuleManager中private的ModuleInfo类的实例。ModuleInfo对象负责加载SWF文件,并被封装成一个实现了IModuleInfo接口的代理类,由ModuleManager.getModule方法返回。你可以监听这个代理类上的状态事件,以便更好地控制应用程序如何与加载的模块进行交互。
下面的例子使用了ModuleManager来控制将模块添加到容器中显示。
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
viewSourceURL="srcview/index.html">
<s:layout>
<s:VerticalLayout/>
</s:layout>
<fx:Script>
<![CDATA[
import mx.core.IVisualElement;
import mx.events.ModuleEvent;
import mx.modules.IModuleInfo;
import mx.modules.ModuleManager;
private var _moduleInfo:IModuleInfo;
private function creationHandler():void
{
_moduleInfo = ModuleManager.getModule("com/myflexhero/MyFlexHeroTest.swf");
_moduleInfo.addEventListener( ModuleEvent.READY,moduleLoadHandler );
_moduleInfo.addEventListener( ModuleEvent.PROGRESS,onModuleProgress);
_moduleInfo.load();
}
private function moduleLoadHandler(event:ModuleEvent ):void
{
BorderContainer.addElement( _moduleInfo.factory.create() as IVisualElement);
}
protected function onModuleProgress (e:ModuleEvent) : void {
label.text = "[MyFlexHero]:ModuleEvent.PROGRESS 当前已经加载了: " + e.bytesLoaded + " of " + e.bytesTotal + " loaded.";
}
]]>
</fx:Script>
<s:BorderContainer id="BorderContainer" width="500" height="200" />
<s:Label id="label" text="[MyFlexHero]:"/>
<s:Button label="点击加载" click="creationHandler()"/>
</s:Application>
MyFlexHeroTest.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Module xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" layout="absolute" width="100%" height="100%">
<s:Panel title="MyFlexHeroTest">
<s:Label text="Hello World!">
</s:Label>
</s:Panel>
</mx:Module>
下面列出了ModuleManager在加载模块时派发的事件,你可以根据需要监听这些事件并完成自定义事件操作
常量 | 字符串值 | 描述 |
PROGRESS | "progress" | 加载模块时被调度。你可以用这个事件访问被加载模块的bytesLoaded和bytesTotal属性。 |
SETUP | "setup" | 当已加载了足够的模块内容时被调度。 |
READY | "ready" | 当模块完成加载时被调度。 |
UNLOAD | "unload" | 当卸载模块时被调度。 |
ERROR | "error" | 当模块下载过程中出错时被调度。 |
From http://www.myflexhero.com/share/flex-hero-flex4/flex-hero-components/flex-module/291
分享到:
相关推荐
`ModuleManager`负责模块的加载和卸载,`ModuleLoader`负责显示和隐藏模块,而`ModuleContainer`可以容纳和布局多个模块。 8. **模块的最佳实践**: - **明确模块边界**:确保每个模块有清晰的责任划分。 - **...
下面将详细探讨Flex模块的使用和模块间的通讯。 1. **Flex模块的创建** 创建Flex模块首先需要一个独立的MXML文件,该文件定义了一个模块类。模块类通常继承自`mx.modules.ModuleBase`,并包含自己的UI组件和业务...
另外,`ModuleManager`类允许对已加载和未加载的模块进行操作,包括获取模块引用。 4. **本地存储和SharedObjects**:如果需要在模块之间持久化数据,可以使用Flash Player的本地存储功能,如SharedObjects。这允许...
使用ModuleManager载入模块 22.9节.载入来自不同服务器的模块 22.10节.与模块通信 22.11节.使用查询字符串传递数据给模块 22.12节.使用连接报告优化模块 第二十三章.Adobe Integrated Runtime API(694) 23.1节.借助...