`
itspring
  • 浏览: 45084 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

从Flex3转变到Flex4

    博客分类:
  • flex
阅读更多

flex4 beta发布了,它是自flex3以来的重大改革。flex4 beta 提供了一种新的组件和皮肤的架构。作为一个flex3的开发者,当你用flex4 beta编译你的flex3应用时你应该不会遇到太大的挑战,因为flex4 beta的一个目标就是保持与flex3的兼容。
在这篇文章里我会提供关于flex4 beta主体带的一个大概的浏览,介绍一下Flex3到Flex4架构上的区别,以及在组件,布局,状态,效果上的改变。这篇文章里,halo代表flex3里的原始组件。spark代表flex4 beta里的新的组件。
将应用迁移到flex4 beta
把应用从flex3迁移到flex4,不会遇到太大的麻烦。除了看到一些bug被修补了以及默认的主题换了,你还会看到你的应用会在flex4里工作的更好。但是还是有些东西你需要注意。
◆播放器的依赖
flex4 beta 需要flash player10的支持。
◆样式选择器需要命名空间
对于一个css样式选择器以前你可能只需要这样写
 

Css代码 复制代码
  1. Button {    
  2.       cornerRadius: 10;    
  3. }    
  4. DateField {    
  5.       color: #780800;    
  6. }  
Button {       cornerRadius: 10; } DateField {       color: #780800; }


但是在flex4 beta里你必须加上命名空间。
 

Mxml代码 复制代码
  1. < mx:Style>    
  2.        @namespace "http://www.adobe.com/2006/mxml";   
  3.         …    
  4. < /mx:Style>  
< mx:Style>        @namespace "http://www.adobe.com/2006/mxml";        … < /mx:Style>



更进一步,如果你用了StyleManager.getStyleDeclaration("Button"),在flex4里你必须把命名空间给加上 如:StyleManager.getStyleDeclaration("mx.controls.Button")。
◆Flex3到Flex4主题的变化
主题已经由默认的halo变成了spark。所以你的应用在flex4里看起来可能会不一样了。当然了,你要是想用halo也是有办法的。你可以用-compatibility-version=3.0这个标识也可以修改additional compiler argument(附加的编译器自变量)为_local en US -theme=halo.swc。
如果你选择用Spark,你会发现很多在Halo里工作的样式到Spark里就不工作了,spark主题只支持有限的样式。想要修改如border之类的外观你需要自定义的皮肤。flex4也提供了一个Wireframe皮肤来帮助你快速建立模型。
除了默认样式的变化,预加载进度条也变化了。这个更轻量级的进度条会缩短启动的时间。你要想还是用原来的加载进度条你只需加上下面这一条:preloader="mx.preloaders.DownloadProgressBar"。
Flex3到flex4 beta架构改变一览
flex4 给设计师和开发者提供一个更平滑的工作流。为了实现这个,flex4框架提供了可视化组件和其行为的明确的分界。 在flex3里一个组件代码包括逻辑,布局和可视化的变化,但是在flex4里一个组件被分配到了不同的类,每个类都掌控不同的方面。
◆flex4里的包和命名空间
flex4里保存了flex3的全部类,它们全在mx.*的包里。当然除此之外,flex还提供全新的spark.*包来保存组件,核心类,效果,滤镜,布局, 皮肤和工具。
flex提供了一套组件,其中很多与halo有同样的名字,为了避免名字的冲突,随flex4而来的是4个不同的命名空间:MXML 2006, MXML 2009, Spark, and Halo。
MXML 2006:过时的mxml语言命名空间,曾用在flex3。如果用flex4编译flex3的应用程序,你依然可以用这个命名空间。
URI: http://www.adobe.com/2006/mxml
默认前缀:mx
MXML 2009: 全新的mxml语言命名空间,是纯的语言命名空间,不包含组件。
URI: http://ns.adobe.com/mxml/2009
默认前缀:fx
SPARK:这个命名空间里包含了所有的新的Spark组件,他应该和MXML 2009一起使用。
URI: library://ns.adobe.com/flex/spark
默认前缀: s
HALO:这个命名空间包含所有halo的组件,应该与MXML2009一起使用。
URI: library://ns.adobe.com/flex/halo
默认前缀:mx
flex4在css方面也提供了多样的命名空间的支持。所以,在使用css时必须注意命名空间已避免冲突。
 

Mxml代码 复制代码
  1. < fx:Style>      
  2.        @namespace s "library://ns.adobe.com/flex/spark";      
  3.        @namespace mx "library://ns.adobe.com/flex/halo";      
  4.        s|Button {      
  5.             color: #FF0000;      
  6.        }      
  7.        mx|DateChooser {      
  8.        color: #FF0000; }        
  9. < /fx:Style>   
< fx:Style>          @namespace s "library://ns.adobe.com/flex/spark";          @namespace mx "library://ns.adobe.com/flex/halo";          s|Button {               color: #FF0000;          }          mx|DateChooser {          color: #FF0000; }     < /fx:Style> 




新的组件和容器
◆组件
flex4修改和新增了一些组件,也有些组件是halo有的,但是spark没有。adobe建议你halo和spark一起用。至于两者都有什么,没什么下面有个网址你可以去看看。
http://www.adobe.com/devnet/flex/articles/flex3and4_differences_04.html
◆state语法的改变
state语法变了,变得更加的有弹性和直接。你甚至可以根据上下文来针对性的改变你的状态。下面是重点:
1,只有状态被定义到了状态数组。
2,AddChild和RemoveChild,不能再用了。取而代之的是includeIn和excludeFrme属性 。这两个属性是组件的属性。
看例子吧!
这是flex3应用状态的方式。
 

Mxml代码 复制代码
  1. < mx:states>     
  2.      < mx:State name="submitState" basedOn="">      
  3.           < mx:AddChild relativeTo="{loginForm}" >      
  4.                < mx:Button label="submit" bottom="10" right="10"/>      
  5.           < /mx:AddChild>      
  6.           < mx:RemoveChild target="{firstTextInput}"/>     
  7.      < /mx:State>      
  8. < /mx:states>     
  9. < mx:TextInput id="firstTextInput" />     
  10. < mx:Canvas id="loginForm" />  
< mx:states>       < mx:State name="submitState" basedOn="">             < mx:AddChild relativeTo="{loginForm}" >                  < mx:Button label="submit" bottom="10" right="10"/>             < /mx:AddChild>             < mx:RemoveChild target="{firstTextInput}"/>       < /mx:State>   < /mx:states>  < mx:TextInput id="firstTextInput" />  < mx:Canvas id="loginForm" />

 
这是flex4
 

Mxml代码 复制代码
  1. < s:states>      
  2.     < s:State name="submitState" />      
  3. < /s:states>      
  4. < s:TextInput id="firstTextInput" excludeFrom="submitState" />      
  5. < s:Group id="loginForm" >      
  6. < s:Button label="submit" bottom="10" right="10" includeIn="submitState"/>     
  7.    
< s:states>       < s:State name="submitState" />   < /s:states>   < s:TextInput id="firstTextInput" excludeFrom="submitState" />   < s:Group id="loginForm" >   < s:Button label="submit" bottom="10" right="10" includeIn="submitState"/>   



3,setProperty,setStyle和setEvent被点语法取代了。
下面是flex3的做法
 

Mxml代码 复制代码
  1. < mx:states>      
  2.     < mx:State name="submitState" basedOn="">      
  3.         < mx:SetProperty target="{submitButton}" name="label" value="submit" />     
  4.         <mx:SetStyle target="{submitButton}" name="textDecoration" value="underline"/>      
  5.         <mx:SetEventHandler target="{submitButton}" name="click" handler="trace('done');"/>     
  6.    < /mx:State>      
  7.    < mx:State name="clearState" basedOn="">      
  8.         < mx:SetProperty target="{submitButton}" name="label" value="clear" />     
  9.         < mx:SetEventHandler target="{submitButton}" name="click" handler="emptyDocument()" />      
  10.     < /mx:State>      
  11. < /mx:states>      
  12. < mx:Button id="submitButton" />    
< mx:states>       < mx:State name="submitState" basedOn="">           < mx:SetProperty target="{submitButton}" name="label" value="submit" />          <mx:SetStyle target="{submitButton}" name="textDecoration" value="underline"/>           <mx:SetEventHandler target="{submitButton}" name="click" handler="trace('done');"/>     < /mx:State>      < mx:State name="clearState" basedOn="">           < mx:SetProperty target="{submitButton}" name="label" value="clear" />          < mx:SetEventHandler target="{submitButton}" name="click" handler="emptyDocument()" />       < /mx:State>   < /mx:states>   < mx:Button id="submitButton" />  



下面是flex4的做法
 

Mxml代码 复制代码
  1. < s:states>      
  2.     < s:State name="submitState" />      
  3.     < s:State name="clearState" />      
  4. < /s:states>      
  5.      
  6. < s:Button label.submitState="submit" textDecoration.submitState="underline" click.submitState="trace('done')" click.clearState="emptyDocument()" label.clearState="clear" textDecoration.clearState="none"/>    
< s:states>       < s:State name="submitState" />       < s:State name="clearState" />   < /s:states>     < s:Button label.submitState="submit" textDecoration.submitState="underline" click.submitState="trace('done')" click.clearState="emptyDocument()" label.clearState="clear" textDecoration.clearState="none"/>  



4,组件不能在无状态或空的状态。它默认的状态时第一个声明的状态。

分享到:
评论

相关推荐

    FLEX 3D螺旋相册

    3D螺旋相册特效则是Flex平台上的一个独特应用,它利用Flex的3D渲染功能,将传统的相册展示方式转变为立体的螺旋动态展示,给用户带来全新的视觉体验。 3D螺旋相册特效的核心在于如何利用Flex中的3D变换技术。在Flex...

    Flex 3 Cookbook简体中文版最新推荐常青

    ActionScript是Flex应用程序的核心编程语言,自3.0版本起,它已从原型脚本语言转变为一种面向对象、类型严格的ECMAScript标准兼容语言。MXML则是一种类似HTML和XML的标记语言,用于描述用户界面组件和应用布局。在...

    flex 竖排Menu

    默认情况下,Flex的MenuBar组件是水平布局的,但通过自定义和编程,我们可以将其转变为垂直布局。这在空间有限或者设计要求独特的场景下尤其有用。 描述中提到,“此为竖排”,意味着原始的MenuBar组件已被修改,使...

    Flex简介Flex简介Flex简介Flex简介

    ria的发展历程大致经历了从主机应用程序到客户端/服务器,再到浏览器/服务器模式的转变,最终发展出如Adobe Flash/Flex、Laszlo和Microsoft WPF/Expression等各具特色的ria客户端开发技术。 Flex作为ria技术的一个...

    划分flex页面布局

    通过设置`display`属性为`flex`或`inline-flex`,可以将一个元素转变为Flex容器。 2. Flex项目:容器内的子元素称为Flex项目,它们是被布局的对象。容器的所有样式规则都会影响到这些项目。 二、主要属性 1. `flex-...

    Flex 3 CookBook 简体中文

    ActionScript是Flex 3中的主要编程语言,自3.0版本起,它已从基于原型的脚本语言转变为一种全面的面向对象、强类型的ECMAScript标准兼容语言。这意味着ActionScript具备了类、接口、包等面向对象特性,开发者可以...

    flex嵌入jsp心得

    标题与描述概述的知识点是关于如何将Flex框架嵌入到JSP页面中,以实现更丰富的数据可视化功能,特别是图表的展示。以下是基于标题、描述、标签以及部分内容的详细解析和扩展。 ### Flex嵌入JSP开发心得 #### 1. ...

    3D中国象棋-flex-away3d实现

    本项目“3D中国象棋”就是这样一个例子,它巧妙地融合了Flex和Away3D引擎,将传统的二维棋盘游戏转变为引人入胜的三维空间体验。本文将详细介绍这一项目的实现原理和技术要点。 Flex,作为Adobe公司推出的基于...

    IBM Flex System –超越刀片

    具体到产品更新,有FlexSystem p260 Entry node适合IBM的客户端、FlexSystem p460 compute node满足对容量和增长需求的企业客户,以及性能卓越的FlexSystem p270 compute node。FlexSystem x222 doubledense compute...

    Flex_4_Fun

    过渡是指从一种状态平滑地转变到另一种状态的过程。本书中对于过渡的讨论主要包括: 1. **过渡效果设计**:如何设计出流畅且自然的过渡效果。 2. **过渡动画控制**:提供了控制过渡动画的方法,例如调整速度、方向...

    Flex 3 Cookbook

    通过上述解析,我们可以了解到Flex 3 Cookbook主要涵盖了Flex与ActionScript的基础知识、MXML与ActionScript的交互细节以及如何使用Flex Builder创建和配置Flex项目等内容。这对于初学者来说是非常宝贵的学习资料,...

    理解Flex3组件和框架的生命周期.pdf

    ### 理解Flex3组件和框架的生命周期 #### 简介 Adobe Flex 是一款强大的框架,用于构建丰富的互联网应用程序 (RIA)。虽然 Adobe 提供了大量的文档支持,但理解和掌握 Flex 组件及其框架的生命周期仍然是一个挑战。...

    Flex,+Silverlight+or+HTML5

    在过去的几十年里,Web已经从一个静态网页的集合转变为一个功能强大的交互式平台。这一转变带来了新的挑战,尤其是在选择正确的技术栈方面。本节首先概述了当前Web应用开发领域的复杂性,并探讨了HTML与插件技术并行...

    Flex 白皮书 编成 flash

    6. **Flex应用生命周期**: 从初始化到销毁,Flex应用有明确的生命周期。理解这个过程对于优化性能和处理状态变化至关重要。 7. **数据绑定**: Flex支持双向数据绑定,使得视图层和模型层的数据能自动同步,降低了...

    Flex 和 ActionScript 关系

    ActionScript 3.0的出现使得Flash从一个单纯的动画工具转变为一个开发RIA的强大工具。 然而,Flex的出现是为了满足更多开发者的需求,尤其是那些熟悉Java、ASP.NET或PHP的程序员。Flex使用MXML(Markup Language ...

    FLEX企业应用开发实战(完整版)

    这本书全面覆盖了Flex技术的核心概念、工具、框架以及实际开发过程中的策略和技巧,旨在帮助读者从初学者到专业人士的转变,尤其对于那些希望利用Flex构建富互联网应用程序(RIA)的企业开发者来说,是一份宝贵的...

Global site tag (gtag.js) - Google Analytics