ActionScript类有两种形式,一种是扩展名为as的,这种类的写法和java非常相似。另外一种是以mxml为扩展名的文件,这种类是以xml文件格式书写的类,其中也可以嵌套as代码。两种文件在Flex中的作用是相同的都代表一个类。在as代码中定义内部类是行不通的,前面已经说明了。只好把眼光放到mxml类型的类中了。在xmxl的标签中,flex提供了一个<mx:Component>标签,这种标签只适用于mxml文件中,用来内联渲染器,多用于DataGrild控件用来功能扩展。<mx:Component>标签有两个属性id和className,id属性属性可以指定一个内嵌组件标识符,以便您可以使用作为数据绑定时数据源的表达式。 className属性指定内嵌组件的类名称,也就是相当于内部类的类名了。这就好办了,既然AS类中不可以有内部类,但是mxml类中可以嵌入组件,组件也是类那就是内部类了。
接下来就可以这样这样做,定义一个mxml组件,该组件可以继承与任意一个可视组件。例如可以继承于Canvas类,创建完毕加入<mx:Component>标签,代码如下所示:
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml" width="400" height="300">
- <mx:Component>
- <mx:HBox>
- <mx:TextInput width="200"/>
- <mx:Button label="OK"/>
- </mx:HBox>
- </mx:Component>
- </mx:Canvas>
我们声明了一个内嵌组件,这个组件继承与VBox类,在这个组件中还添加了一个文本框和一个按钮。这个内嵌组件可以有自己的AS代码这些代码和外部类的代码是没有冲突的。如下所示:
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml" width="400" height="300">
- <mx:Component className="MyInput">
- <mx:HBox>
- <mx:Script>
- <!--[CDATA[
- import mx.managers.PopUpManager;
- public var text:String = "test property";
- private function onClick():void
- {
- text = txt.text;
- PopUpManager.removePopUp(this);
- }
- ]]>
- </mx:Script>
- <mx:TextInput id="txt" width="200"/>
- <mx:Button label="OK" click="onClick()"/>
- </mx:HBox>
- </mx:Component>
- <mx:Script>
- <![CDATA[
- import mx.managers.PopUpManager;
- import mx.core.Application;
- import mx.core.UIComponent;
- private var mi:MyInput = null;
- private function onClick():void
- {
- mi = PopUpManager.createPopUp(UIComponent(Application.application),MyInput,true) as MyInput;
- PopUpManager.centerPopUp(mi);
- lb.text = mi.text;
- }
- ]]-->
- </mx:Script>
- <mx:Button label="show popup" click="onClick()"/>
- <mx:Label id="lb" width="353" y="30" height="27"/>
- </mx:Canvas>
在上面这个例子中,内嵌组件完全可以当成是一个内部类来使用,可以创建对象,可以访问该对象的方法和属性。当使用内部类的时候需要注意以下几点:
1、内嵌组件有一个关键字“outerDocument
”用来访问外部类的公共属性和方法,但是仅限于内嵌组件用于item renderer 或者 item editor的时候。以上这种用法,是不可以使用outerDocument
关键字的。
2、在写内嵌组件的时候,FlexBuilder很有可能没有语法提示,没关系,只要按照上面例子的格式,不用理它继续写就可以了。
3、这是我遇到的一个问题,内嵌控件最好定义在文件的上部,当外部控件的AS代码写得多了以后,可能会出现找不到内嵌控件这个类的编译错误。这个确实很奇怪,注意一下就可以了。