《Flex问题解决大全》word版.doc
《《Flex问题解决大全》word版.doc》由会员分享,可在线阅读,更多相关《《Flex问题解决大全》word版.doc(43页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1、flex包含一个基于组件的开发模型,你只需要按需求继承现有的组件并扩展相关的方法就可开发你的应用。2、可视化组件包括以下主要特性:尺寸、事件、样式、效果、皮肤。3、flex定义了两套组件。一套为Spark,放在spark.*包下。一套为MX,放在mx.*包下。Spark是在flex4中新添加的,mx为旧版本中定义的。两套组件的主要不同点在于样式及皮肤的使用。另外对于容器组件,布局的方式也改变了。4、有些组件在两套UI中都存在,例如按钮,在这种情况下adobe建议你使用Spark中的组件。有些组件是某套UI特有的。例如Spark中的3d效果。mx组件中的数据可视化组件,例如DataGrid、
2、AdvancedDataGrid。所以你的应用会包含两套UI中的组件。5、可视化组件的继承层次结构:Object-EventDispatcher-DisplayObject-InteractiveObject-DisplayObjectContainer-Sprite-FlexSprite-UIComponent。flex中所有的可视化对像都继承自UIComponent。6、UIComponent中需要注意以下属性。doubleClickEnabled:flex默认是不支持双击的,如果要开启双击,请把该属性设为true;height:在mxml中你可以设置值为数字,这时默认单位为pix。你也可
3、以设置为70%这种比例。在as中,如果要设置百分比,你需要用percentHeight这个属性。x,y:这组属性只在layout为绝对布局时才有效。7、每一个flex组件都有对应的mxml接口和as接口。两者之间是相等的。8、每个一可视化组件都包含以下三个生命周期事件:preInitialize:组件刚被创建,还没有添加子节点,且不可见。initialize:把子节点初始化好,并尺寸也设置好,但仍然处于不可见状态。creationComplete:组件已经被放在父容器中而且可见。你可以使用上面三个事件对组件做一些初始化工作。9、flex提供了多种设置组件大小和布局的机制。默认大小:如果你不指定
4、组件的大小或布局,flex会自动设置一个适合的值。显式设置大小:你可以显式地设置组件的height/width大小。基于比例的设置大小:例如在mxml中设置height/width=70%或在as中设置percentHeight/percentWidth=70。基于约束的布局:你可通过组件中的样式属性:top,buttom等设置组件的布局及大小。这种设置方式只可以使用在父组件为绝对布局的情况。10、flex应用是基于事件驱动的。事件可以让程序员知道用户与UI的交互、组件的生命周期及外观变化。当一个组件分发事件,所以对该组件进行监听的监听器都会被通知。11、除了用选择器设置组件的外观外,还可以直
5、接调用元素的setStyle(proName,value)设置外观。12、flex4中的类选择器需要使用命名空间。例子代码:namespace s library:/ s|BorderContainerborderColor:red;。13、效果(effect)是组件在一段时间内的视觉或听觉上的变化,例如退色,位移等。14、数据绑定是源属性(source)发生变化时,目的(destination)属性会自动产生变化。15、flex提供了三种数据绑定的方式。第一种是在mxml中使用括号在目的属性中对源属性进行绑定。第二种是在mxml中使用标签对源属性与目标属性进行绑定。第三种是在as中使用Bin
6、dingUtils方法对源属性与目标属性进行绑定。16、数据绑定符可以直接对属性进行引用,也可以对方法进行引用。例如:obj.text.toUperCase()17、数据绑定符和两种方式对数据进行绑定是从编译时就开始的。而BindingUtils即在运行时才开始绑定。18、可绑定符的意思是当对应的属性变化时,会触发数据绑定事件,通知绑定的目标属性。19、当源对像分发initialize事件以及在源对像变化时都会触发数据绑定事件。20、如果你创建一个对像,并想让它可以成为数据绑定的源,那属性前面必需加上Bindable/Bindable(eventname)/Bindable(event=eve
7、ntname)标签。当你直接使用Bindable标签时,实质上等价于Bindable(propertyChange)。当属性发生改变时,flex会分发propertyChange事件给绑定于此属性的绑定目标对像。21、通过标签或BindingUtils可以把多个源属性绑定到一个目标对象。绑定后,任意一个源发生改变时,目标对像都会被更新。22、双向绑定:数据的任意一方发生变化时,另一方都会被通知并改变。数据绑定表达式:。数据绑定标签:。另外样式、效果、RPC中的request和arguments对像都不支持双向绑定。23、使用方法作为数据绑定的源。当方法的参数为Bindable时,参数的改变会触
8、发数据绑定事件,让目标属性的值更新为方法的结果。如果方法中没有Bindable参数,即目标属性只会在开始时被更新一次。24、如果你想绑定一个方法作为源数据,但该方法又没有可绑定的参数时可以使用Bindable(event=evenname)标签,当该对像分发dispatchEvent(new Event(eventname)时,绑定到方法的目标属性就会被更新。25、在类定义的地方便用Bindable标签等价于在该类中的所有public属性以及有对应的set/get方法的属性中加上Bindable标签。27、在定义一个属性的地方使用Bindable标签的作用是当该属性被替换成另一个值时,目标属性
9、会接收到通知事件,并更新值。这里要注意的是只有被替换时才更新,如果只是该属性中的某个属性被改变的情况,目标对像是不会被更新的。28、在数组(ArrayCollection)中使用Bindable标签时,无论是数组被替换还是数组中的元素改动,都会触发更新事件。29、如果只绑定数组中的某个元素时,应使用getItemAt()。这样该元素被替换时会触发更新事件去更新目标对像。但如果使用num的形式进行绑定时,不会触发更新事件。30、在数据绑定符()和数据绑定标签()中,你可以使用as表达式。例如Number(obj.text)*6/7和ex4表达式。但不能在BindingUtils.bingProp
10、erty()/bindSetter()中使用。31、as中的方法绑定接口。BindingUtils.bindSetter(funToCall,sourceObj,sourceObj.property):ChangeWatcher。32、你可以使用ChangeWatcher.watch(sourceobj,sourceobj.property,listener);方法添加一个监听器,当绑定时件触发时,listener会被调用。33、如果源属性被替换,但被替换的对像与原对像是同一个对像,这种情况下更新不会被触发。如果你想自已控制事件触发,你可以在Bindable(eventname)中指定事件名,
11、然后在想更新时通过dispatchEvent(new Event(eventname)的方式触发。34、数据绑定源中的整个属性链(chain)中的每一个节点都需要Bindable,如果只有最未端属性是Bindable,那链中的其它层属性被更改时,不会触发更新事件。35、如果你把对像绑定到dataProvider的话,当你需要改变其中一个对像的一个属性时,你需要以下代码obj.dataprovider.editField(index,propername,value);这样更新对像才会同时更新到显示组件中。36、如果你把Array绑定到显示组件中时,该组件只在初始化时更新一次值。初始化后,当Ar
12、ray中的项改变时,不会触发更新。37、容器提供了一个层次结构让你去布局组件。38、flex最顶层容器叫application。39、flex容器有两种,一种是布局容器(layout container),另一种为导航容器(navigator container)。布局容器用于布局子组件/子容器的大小和位置。导航容器用于多个容器的导航。导航容器只能够用mx容器及spark的NavigatorContent容器。40、mx组件容器只能存放继承自UIComponent对像的组件,而spark容器可以放下实现IVisualElement接口的组件。IVisualElement在UIComponent
13、对像的继承层次中被实现。41、mx容器与spark容器的主要区别在于mx组件的布局是固定的,而spark组件的布局是可以被替换的。42、创建策略(Creation Policy)。创建策略指定了容器对子组件的初始化进程。创建策略有三个选项:ContainerCreationPolicy.AUTO/NONE/ALL。all:开始时初始化所有容器。NONE:不初始化所有子容器。AUTO:子组件在被需要时才创建,例如如果设置了AUTO选项,导航容器中除首页外,其它页的子组件在点击后才会被创建。43、如果把一个容器的layout属性设为null,即该容器会采用它父容器的布局。44、初始化事件顺序:pr
14、einitialize(自外向内),contentCreationComplete(容器特有,自内向外),initialize(自内向外),cteationComplete(自内向外)。45、容器中有一个enabled属性,如果该属性设为false,即所有节组件都处于enabled=false状态。46、容器中的defaultButton属性。设置该属性后,当用户在该容器上按回车键时,该按钮被触发。47、spark中的四种布局:BasicLayout(绝对定位或约束布局),HorizontalLayout(单行水平布局),VerticalLayout(单身垂直布局),TileLayout(多行
15、表格布局)。48、spark容器中如果放置一个大于该容器的组件,默认情况下该组件会越过容器显视。49、如果要把组件的显视限制在容器内,可以使用viewport和scrollbar。50、viewport定义了两个区域,一个为逻辑区域(logical content),另一个为可视窗口(visible window)。逻辑区域包括所有的子组件。显视区域是用户能看见的,是逻辑区域的一个子集。51、veiwport的contentHeight/contentWidth是逻辑区域的大小,它的大小由子组件决定。52、height/width是可视窗口的大小。53、verticalScrollPositi
16、on/horizontalScrollPosition是可视化窗口相对于逻辑窗口的坐标。坐标为负时,可视化窗口向左上移。为正时向右下移。54、viewport中的clipAndEnableScrolling属性默认为false,即如果子组件的大小大于容器,那子组件将越过容器边界显视。如果设置为true,即超出容器部份将不显视。55、可以通过三种方法为容器增加滚动功能:1,增加HScrollBar/VscrollBar。2,把容器放到Scroller中。3,在容器使用的皮肤中加入Scroller。56、在H/VScrollerBar中设置viewport中指定该bar的目标容器。当滑动滚动条时,
17、滚动条会改变容器的verticalScrollPosition/HorizontalScrollPosition的值。57、放在scroller中的容器的clipAndEnableScrolling的值为true。58、只有实现了viewport接口的容器都才能使用scroller。如果容器没实现viewport,例如BorderContainer、SkinnableContainer,即可以在此容器内放置scroller然后再放实现了viewport的容器。也可以先在scroller内先放置group,然后再放置没实现viewport接口的容器。59、mx组件容器默认就支持滚动,当clipC
18、ontent为true而且子组件超出容器边界时,滚动条自动出现。如果需要滚动条一直出现,可以设置horizontalScrollPolicy和verticalScrollPolicy属性为true。60、显视列表中对节点的操作方法,在Spark与mx组件中是不同的。主要的不同点是spark组件的方法名中大部份含有Element,而mx组件中则以Child代替。61、在显视列表中调用numElements/numChildren方法得到的是直接子节点的数目。62、flex/flash有三个坐标系统:全局(global),本地(local),内容(content)。63、全局坐标是以舞台(stag
19、e)的左上角为坐标原点的坐标系统。在MouseEvent中有stageX和stageY属性就是全局坐标系统中的坐标轴。64、本地坐标是相对于组件左上角的坐标。所有组件都有的mouseX与mouseY属性指的是本地坐标系统的值。MouseEvent中的localX与localY也是本地坐标系统的值。而拖放操作中的xOffset与yOffset也是。65、内容坐标是是相对于组件内容的左上角。与全局和本地坐标不同的是内容坐标包括组件的内容区域。组件中的contentMouseX/contentMouseY属性是内容坐标的值。66、在鼠标事件中的内容坐标与本地坐标是针对事件的目标对像,而目标对像并不是
20、一定是你操作的对像。所以一般情况下你需要把本地坐标转化为全局坐标然后再把全局坐标转化为内容坐杆。67、所有的可视化组件中有关坐标的属性。contentMouseX/contentMouseY:鼠标在组件中的内容坐标。68、所有的可视化组件中有关坐标的方法:contentToGlobal/contentToLocal,globalToContent/globalToLocal,locatToContent/localToGlobal。69、布局(layout)分两部份,一部份为尺寸(sizing)另一部份是定位(positioning)。70、布局管理器(layout manager)通过三个阶
21、段去布局你的组件。保证阶段(Commitment pass),测量阶段(Measurement Pass),布局阶段(Layout Pass)。在保证阶段,管理器先确认你设置的组件的一些与布局有关的值。此时管理器会调用各组件的commitProperties()。在测量阶段,管理器为各组件设置或计算一些尺寸相关的属性的默认值。此阶段管理器会调用各组件的measure()方法。在布局阶段,管理器会移动和设置组件以及相关的画图方法。此时管理器会调用各组件的updateDisplayList()。71、flex在程序初始化时(initializes)时或在一些与布局相关的属性改变时会自动进行布局。7
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Flex问题解决大全 Flex 问题解决 大全 word
限制150内