Flex的背景和技术特点

作者:网络 来源:佚名 更新时间:2008-12-17 15:06:44 点击:

《flex 3 ria开发详解与精深实践》
flex 3程序设计基础

flex 是一种ria开发技术,具有更好的网络交互能力,更加绚丽的表现效果,同时在企业级的扩展上也游刃有余。flex技术对软件开发人员的要求并不苛刻,mxml和actionscript都遵循技术标准,用相对简单的代码就可以完成绚丽高效的flex应用程序。

作为flex技术的组成部分,flex charting让我们可以灵活地进行图表编程,flex data service让我们可以将flex应用程序部署成为企业级应用。

flex builder是一个实用的集成开发环境,通过这个环境,可以高效地完成flex程序的编写。

1.1  ria概述

本章内容介绍flex的背景和技术特点,并通过示例程序来展示flex的界面效果和技术内涵。

internet已经是我们生活的一部分,而“看网页”可以说是网络浏览者与internet最简单的沟通方式。打开浏览器,进入一个网站浏览,这就是浏览者们看到的最直观的internet的外表。尽管页面上不是单一的文字,但也仅仅是“页”。然而如今这些传统的呆板的“页”已经不再能满足网络浏览者的要求了。多媒体、多元化的信息表现在一个页面上,的确很是单薄。

另一方面,开发人员也一直在为过分依赖于页面刷新、请求响应等诸多传统网页开发技术固有的问题而烦恼。当然我们不能忽略b/s架构能够取代c/s长期大行其道有一个重要的因素,就是网络带宽问题。

传统网页内容简单,节省网络带宽的优势是与生俱来的,而如今网络技术在不断地发展,软硬件发展又达到了一个并驾齐驱的时期,软件系统已经不需要等待硬件的发展而发展。有了强烈的需求,又有了充足的硬件基础,新技术应运而生,rich internet application (ria)的出现给网络浏览者和开发人员都带来了全新的体验。

rich internet application即是富因特网应用程序,其特点也体现在一个“富”字上,传统的html页面带给用户的页面元素是极其有限的,输入框、选择框、下拉框等无法替换的元素,恐怕早就对浏览者带来了审美疲劳,更何况在功能上也存在着很大不足。对比传统页面,ria的界面是“富”的,基本上一个桌面程序能表现出来的效果,ria都能表现。

图1.1中的网站是一个名为scrapblog的博客网站,与我们常见到的博客网站不同,这个网站使用一种ria技术构建,在页面表现力和交互性上都远远超过了常见的博客网页。

图1.1  使用ria技术实现的网站——scrapblog (点击上图放大)

如果说ria的优势仅仅是丰富的界面表现能力的话,那么大家会认为这不过就是个c/s架构,ria的另一大特点也正是与c/s架构最大的不同:数据上的“富”。传统的网页开发基于http协议,数据的交互依赖于请求/响应机制;界面的交互则需要进行页面的跳转和刷新。ria的处理则有很大不同,在客户端可以进行完整的数据处理,与用户的交互更加友好、更加迅速;界面交互并不依赖页面,消息通过异步请求传递,面向用户界面中的各个小模块,客户端的模块之间关系清晰,处理起来更加灵活。

对于企业级应用来说,ria技术并不需要替换掉现有的体系结构模型,如javaee(以前称j2ee)、.net架构等。ria技术通常可以和企业级应用体系结构很好地进行整合。将原有的系统构建成更易用、更直观、更迅速的“网页应用程序”。在不会影响到原有应用的前提下,ria技术对表现层进行了大幅度的增强,进一步提升界面的友好程度,并且减少了用户与系统的远程交互频率,减少了带宽需求。

ria开发技术已经有很多种,adobe公司的flex发展日趋成熟,微软公司的silverlight及sun公司的javafx也崭露头角。flex技术的优势得天独厚,有强大的flash平台作后盾,silverlight和javafx在ria的实现上则各有侧重,silverlight作为一个浏览器插件支持广泛,而且对于javascript和微软的.net技术无缝结合,而javafx体系不仅希望利用编写更容易的javafx script取代javascript,更是提供了javafx mobile,为手机及移动设备增加了应用程序支持。

|||

 

1.2  flex简介

flex是一种基于标准编程模型的高效ria开发产品集,最初由macromedia公司在2004年发布,后被adobe公司冠以商标。flex最大的特点是基于全球流行的网络动画平台——macromedia flash。2000年以来,flash动画愈发火爆,“闪客”们的作品为internet增添了绚丽的色彩,而flash的播放器flash player已经成为浏览器上首选的不可或缺的插件,为了看到页面中生动的flash动画,大部分浏览者都会安装flash player。通过flex技术,开发人员可以将ria程序编译成为flash文件,为flash player所接受,也就是说,flex技术所开发出来的程序对于大部分浏览者而言并不需要安装额外的客户端支持,这是一个得天独厚的优势。

“基于标准编程模型的高效ria开发产品集”,这是adobe公司对flex技术的官方定义。下面我们就来进行详细的分析。

一个完整的flex程序由mxml代码和actionscript代码组成。mxml基于xml标准,用于配置和设计flex程序的界面及编写表现层数据模型;actionscript基于ecmascript,原来用于设计flash动画,其语法规范类似于javascript。这样两种基于w3c标准的开发语言就构成了flex程序,两种语言的关系类似于html和javascript,这样一来(尤其对于传统网页开发者来说),flex根本没有什么门槛。

flex 3是flex的一个成熟版本,它的产品集包含以下几部分。

1. adobe flex 3 sdk

flex sdk是flex产品集中最基础的也是必需的组件,使用其他组件必须在sdk的基础上,单独通过sdk就可以完成常用的程序设计。

2. adobe flex builder 3

flex builder是一个基于eclipse的集成开发环境,通过flex builder 可以对程序进行所见即所得的界面设计,并支持mxml和actionscript的智能编写,可以在很大程度上提高flex开发的效率。

3. adobe livecycle enterprise suite

livecycle es是flex企业级开发部署套件,以应用于企业级组件,使得flex可以部署到javaee应用服务器上。

flex 3 sdk的系统需求如下。

  • windows平台:windows 2000,xp,server 2003,java 1.4~1.5
  • macintoshi平台:mac os x v.10.4.x,java 1.5
  • linux平台:red hat enterprise linux 3~4,suse 10,java 1.4~1.5
  • solaris平台:solaris 9,10,java 1.4~1.5
  • 处理器需求:intel pentium ii 450mhz或更快/powerpc g3 500mhz或更快/ modern processor(800mhz或更快)
  • 内存需求:512mb ram(推荐1gb)
  • 硬盘需求:200mb可用硬盘空间

可见开发flex的硬件需求并不很高,当前主流的计算机都可以胜任。flex技术的所有资源下载都可以通过 http://www.adobe.com 获得。

|||

 

1.3  mxml

mxml是一种基于xml的标记语言,在flex技术中,mxml用于设计用户界面,实现丰富的flex表现层。从作用上说,mxml和html的功能是基本一致的,都是设计用户界面,但是mxml提供了较html更为丰富的界面组件,并且在开发上更为结构化,条理更加清晰。

mxml的编写同样类似于html,它通过标签来定义和描述组件。按照学习编程的惯例,下面请看一个用mxml编写的hello world示例。

示例1.1  hello world

<?xml version="1.0"?>
<mx:application xmlns:mx="http://www.adobe.com/2006/mxml">
<mx:panel title="flex mxml test" x="10" y="10" fontsize="12">
<mx:label text="hello world. 世界,你好!" fontweight="normal" fontsize="24" fontfamily="times new roman" fontstyle="italic" alpha="1.0"/>
</mx:panel>
</mx:application>

通过示例1.1的代码可以看到,虽然mxml是类似于html的格式,但是panel、label等开发组件表达了一个gui开发平台才具备的特征。mxml是基于xml语言的,可读性很强,由标签(tag)、标签中的属性(attribute)及属性值(attribute value)等元素组成。

那么,如何才能运行起这个hello world呢?

第一,用一个普通的文本编辑器,如记事本、editplus等,编写并保存上述代码,需要注意的是文件扩展名要保存为小写的mxml,如 test.mxml,我们暂且把它保存在c盘的user文件夹下。

第二,使用flex 3 sdk的命令行进行编译,flex的编译工具在sdk的bin文件夹下,如flex 3 sdk解压缩到c盘根目录,那么在命令行执行(本书所有代码示例部分都默认使用c:\user作为代码文件夹):

cd c:\flex_sdk_3\bin
mxmlc c:\user\test.mxml

可以看到在user文件夹下生成了test.swf文件。

第三,用浏览器或flash player打开这个swf文件,就看到了这个hello world的运行效果,如图1.2所示。

图1.2  hello world运行效果

结合图1.2我们来分析一下这个程序的代码。

<mx:application>是mxml的根元素,是mxml所有组件的容器。在这个标签中,我们要声明mxml的命名空间。

<mx:panel>是个面板组件,是gui程序开发的常见组件,其功能是个组件容器。我们把它的标题设置成了“flex mxml test”,并对位置尺寸进行了设定。

<mx:label>同样是gui程序开发必不可少的组件之一,常用于文字容器,在图1.2中,这个label的内容就是“hello world. 世界,你好!”这个字符串,并将其嵌套在一个<mx:panel>中。在这个程序里,<mx:panel>是<mx:label>的容器。

这就是一个标准的mxml的大致写法。需要特别注意的一点是,在第一行的<?xml version=“1.0”?>中有时候需要进行指定的编码,我们用文本编辑工具处理的时候要保存成对应的编码,如为了方便处理中文和国际化,我们可以把第一行改写成<?xml version=“1.0” encoding=“utf-8”?>,并将代码保存为utf-8格式。

|||

 

1.4  actionscript

actionscript是为adobe flash设计的面向对象的程序设计语言,在flex开发中,actionscript的基本作用类似于传统网页开发中的javascript,同时actionscript还要负责flex程序的逻辑控制和业务建模。actionscript遵循欧洲计算机制造商协会(ecma)通过的ecmascript标准,而ecmascript出自javascript派生出的标准ecma-262,因此无论是使用语法还是技巧方面,actionscript与javascript都非常相似。

作为flex技术的组成部分,actionscript充当着更加重要的角色。如果说mxml是flex亮丽的外表,那么actionscipt就赋予了flex聪慧的灵魂。对于开发者而言,在actionscript上所下的功夫要大于mxml,mxml作为界面表现层需要更多的是外观设计,而actionscript则需要担当起用户交互、数据处理和业务逻辑处理的重任。不仅如此,在mxml中所使用的panel、label等flex内建组件都是基于actionscript类实现的,应用actionscript可以继承这些内建的组件对象来创建自定义的flex组件,使得开发的灵活性大大增加。actionscript的应用还可以涉及到表现层数据模型以及异步远程请求及响应的事务处理。

我们可以通过<mx:script>标签在mxml文件中插入actionscript代码或导入actionscript类文件。而在编译过程中,actionscript代码和mxml代码都会被分离成actionscript类,最终编译器连接所有的actionscript类,编译生成swf文件。

1.4.1  在mxml中使用actionscript脚本

mxml使用<mx:script>标签实现对actionscript的内部编译支持,因此,actionscript脚本代码可直接在标签内编写,此时actionscript以方法为基本单位独立作用,可在mxml代码中直接调用。这里需要注意的是,mxml内部嵌入actionscript代码的方式并非使用了单独的编译机制,在mxml进行编译的过程中,内部的actionscript代码会被抽取出去并创建独立的actionscript类文件,最后组合到swf文件之中。

下面来看一看在mxml内部使用actionscript的示例程序。

示例1.2  使用actionscript脚本

<?xml version="1.0" encoding="utf-8"?>
<!--此示例程序中要使用中文,因此进行编码声明,请注意保存时选择正确的编码-->
<mx:application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:script>
<![cdata[
public function changetext():void {
    disp1.text = "使用actionscript";
}
]]>
</mx:script>
<mx:panel title="flex actionscript test" paddingtop="10" paddingbottom="10"
  paddingleft="10" paddingright="10" x="10" y="10" fontsize="12">
<mx:label id="disp1" text="hello world. 世界,你好!" fontweight="normal"
fontsize="24" fontfamily="times new roman" fontstyle="italic"
alpha="1.0"/>
<mx:button label="点击这里"  fontsize="16" click="changetext()"/>
</mx:panel>
</mx:application>

示例1.2的程序基本是对上一个helloworld示例的扩充,我们对label添加了一个id属性,并在<mx:script>中对这个id进行引用,请特别注意<mx:script>标签在mxml中的引用方式,其内容为actionscript代码,因此要用<![cdata[  ]]>括起来保证对其作为一个字符内容的引用,否则actionscript代码中的操作符很容易与xml的关键字发生冲突,如<、>、&等符号在xml中都有特定的意义。

下面来看看这个示例的运行效果。

如图1.3所示,这次运行的效果多了一个按钮组件,即代码中的<mx:button>,并且我们设置了按钮组件的click属性,即设置了按钮的单击触发为执行actionscript方法changetext(),接下来可以单击按钮查看效果,结果如图1.4所示。

图1.3  actionscript测试运行效果一

图1.4  actionscript测试运行效果二

在图1.4中,label的文字内容被替换成为字符串“使用actionscript”。我们可以看到actionscript代码中changetext()方法的作用是,响应一个按钮单击事件,通过属性id引用mxml的界面组件,并通过用户交互来处理组件的变化,这是actionscript最常见的应用方法。本示例中,通过changetext()方法对id为disp1的label组件进行text赋值操作,通过这个示例我们可以熟悉一下actionscript的一些语法规则,public function changetext():void是actionscript的方法定义,访问控制字为public,而function是方法定义关键字,方法名称为changetext,返回值类型为void。在mxml代码中直接嵌入actionscript时不需要设计actionscript类,直接以方法作为执行单位。

如果是简单的事件响应处理,如输入校验、组件可见性控制等处理,那么用上面的方法还没有问题,但如果需要对数据进行复杂的逻辑操作或者需要对mxml的组件进行定制操作,就需要actionscript类来完成了。

1.4.2  使用actionscript类

在上面的示例中,我们把actionscript代码嵌入到mxml中使用,如果大量的程序脚本都集中在mxml文件内,会给开发和维护都会带来极大的不便,因此在开发时要注意尽量将actionscript代码从mxml文件中分离出去。

对actionscript代码进行分离的最简单方法也是通过<mx:script>标签来实现,需要设置<mx:script>标签的source属性。例如我们的actionscript文件是includes文件夹下的tools.as,那么可以通过<mx:script source=“includes/tools.as”>来实现对actionscript文件的引入,这样actionscript的代码部分可以从mxml中分离出去。

但是仅仅用上述方式分离代码还是不够的,这种方式仅仅在书写上将actionscript代码单独分离出去,与html中引入javascript的方式是完全一致的,而文件对实际的程序设计和代码维护并没有起到作用,因此使用<mx:script>的source属性容易造成误区,导致actionscript的滥用。对于规模较小或逻辑很清晰的ria应用,仅使用actionscript方法就可以满足大部分要求,而对于一个较大的软件项目或者比较复杂的ria应用,必须对actionscript类进行设计。

actoinscript是面向对象的程序设计语言,而类是面向对象程序设计语言的精髓。面向对象的特性(封装、继承和多态)都被actionscript很好地支持。使用actionscript进行开发时,可以使用所有的面向对象特性。

在sdk的功能支持上提供了完善的api,使用actionscript类可以实现系统的所有逻辑操作和数据模型处理,实现对系统的分层开发,同时也用于进行企业级模块的构建;对于界面开发,可以使用actionscript类对现有的mxml类继承并进行定制化开发,也可以在组件操作上实现自定义的功能。

actionscript使用包(package)对类进行组织,定义一个包的同时,相当于隐含规定了一个命名空间,可以很好地解决类的组织问题。不同的包下可以放置同名的actionscript类,在不同的包中调用类需要用import语句来导入,因此可以很好地避免同名类的冲突问题。对于类文件在计算机中的物理位置—— 需要用与包名称相对应的文件夹名来存放,如net.airdev.book这样一个包下的类文件,应该在net\airdev\book\这样的文件夹路径之下进行保存,包结构与文件结构完全对应。有java开发背景的开发者对包肯定不会陌生,actionscript中包的使用与java中是基本一致的。

下面对一个以flex实现的四则运算计算器程序进行结构设计,并在程序中实现一个自定义组件,程序设计类图如图1.5所示。

图1.5  calculator程序设计类图

我们把mxml文件视为一个控制表现层的类class4mxml,在mxml中要建立输入框、计算方法选择按钮和计算按钮,其中计算按钮使用一个继承自button的自定义组件mybutton。

程序需要负责计算的功能模块,因此我们设计一个calculator类,这个类提供一个计算方法run,该方法需要三个参数,两个操作数arg1、arg2和一个计算方法标记method。

代码文件夹结构如下:

c:\user\test.mxml
c:\user\mycontrols\calculator.as
c:\user\mycontrols\mybutton.as

示例1.3a  计算器应用程序的mxml代码

<!--test.mxml-->
<?xml version="1.0" encoding="utf-8"?>
<mx:application xmlns:mx=http://www.adobe.com/2006/mxml xmlns:cmp= "mycontrols.*" >
<!--声明一个名为cmp的命名空间,以此来引用mycontrols包中的自定义组件-->
<mx:script>
<![cdata[
import mycontrols.*;
//通过import命令导入mycontrols包中的类
var calcul = new calculator();
//实例化一个calculator类
]]>
</mx:script>
<mx:panel title="flex actionscript test" paddingtop="10" paddingbottom="10" paddingleft="10" paddingright="10" layout="absolute" height="180" width="304">
<!--把panel的layout属性设置为absolute,从而对这个panel上的组件进行坐标定位-->
<mx:label id="ta1" text="calculator test" fontweight="bold" fontsize="16" width="250" height="30" x="10" y="10"/>
<mx:textinput id="n1" width="77" x="10" y="46"/>
<mx:textinput id="n2" width="77" x="198" y="46"/>
<mx:textinput id="res" width="77" x="74" y="99" enabled="false"/>
<!--设置输入和输出所需要的textinput组件-->
<cmp:mybutton click="res.text=calcul.run(number(n1.text), number(n2.text),tp.value).tostring()" x="196.5" y="99"/>
<!--配置一个自定义组件mybutton,并设定该组件的单击事件执行calc1的run方法,并将结果转换成string类型,显示在id为res的texinput组件上-->
<mx:label x="47.5" y="101" text="=" width="18"/>
<mx:combobox id="tp" x="112" y="46" width="60">
<mx:dataprovider>
<mx:array>
<mx:object label="+" data="0" />
<mx:object label="-" data="1" />
<mx:object label="*" data="2" />
<mx:object label="/" data="3" />
</mx:array>
</mx:dataprovider>
</mx:combobox>
<!--配置可选择的操作符,支持四则运算-->
</mx:panel>
</mx:application>

这个mxml的编写方法与前面的示例基本一致,只是增加了命名空间以支持自定义组件mybutton的使用,并对各个组件的定位进行了一些坐标控制。

示例1.3b  计算器应用程序的actionscript代码

//calculator.as
package mycontrols {
//包声明
public class calculator {
//类声明
public function run(a:number,b:number,c:number):number {
//函数声明。变量a和b为操作数,变量c为计算类型
var res:number;
//计算结果通过res变量返回
if(c==0){
res = a + b;
}
else if(c==1){
res = a - b;
}
else if(c==2){
res = a * b;
}
else if(c==3){
res = a / b;
}
return res;
}
}
}
//mybutton.as
package mycontrols {
import mx.controls.button;
import flash.events.mouseevent;
import mx.controls.label;
public class mybutton extends button {
public function mybutton() {
this.label = "go";
this.setactualsize(100, 30);
}
}
}

示例1.3的程序由以上3个程序文件组成,text.mxml为表现层,在mxml初始化时创建了一个calculator的实例;calculator.as和mybutton.as 分别对应两个功能模型,calculator类提供了一个计算器方法,而mybutton类则继承了mxml的标准组件button类,本程序中的自定义组件仅仅是在组件构造方法中实现了对label属性和定位的初始化,在实际应用过程中,对组件类的继承可以进行更复杂的定制化操作。

程序运行效果如图1.6所示。

图1.6  calculator程序的运行效果

|||

1.5  flex的事件机制

事件处理是gui开发的重要组成部分,早在传统的client/server开发中,事件驱动的开发法就已经是gui开发的主流。

1.5.1  flex事件处理

软件开发者在开发过程中只关注某个组件响应某个事件后所做的操作,即被驱动的操作,而不用像结构化线形开发那样去关注驱动事件的动作。响应特定事件的组件叫做事件监听器(event listener)。

一个用于交互的gui组件会被预先定义它可能遇到的事件,软件开发者即可根据开发需求来编写事件监听器,响应部分或全部的事件触发,图1.7展示了这个触发过程。作为开发者,我们首先需要了解特定的gui交互组件支持哪些事件,之后便可以根据需求写出相应的事件监听器。

图1.7  gui系统中的事件处理流程

在示例1.2和示例1.3中,我们已经使用到了flex的事件机制,flex开发基于actionscipt对象,事件已经作为flex可视化组件的属性。我们可以在mxml中直接为组件的事件属性设定事件监听方法或者代码。

在示例1.2中,我们设定<mx:button>的单击事件(click)属性为click=“changetext()”,并写了一个changetext方法作为单击事件的监听器。这样,当单击button的时候,就会触发button的click事件,changetext方法将被调用。而在示例1.3中,我们把actionscript脚本直接复制给了click,这样整个脚本将作为一个事件监听器。flex可视化组件开发的事件处理方式与html页面开发中的javascript脚本使用是非常相似的。

如果我们需要在事件监听器中处理事件源,即产生事件的组件,那么需要为事件监听的方法传递参数event,例如可以对示例1.2中事件监听方法的定义和<mx:button>的事件属性做一些修改。

(1)  事件监听方法定义的修改:

public function changetext(event:event):void

(2) button事件属性的修改:

<mx:button label="点击这里" fontsize="16" click="changetext(event)"/>

在button事件属性的修改中,event作为一个关键字来使用,而非自定义变量,因此我们可以在标签中直接使用event来创建当前组件所触发的事件对象。

actionscript类event构建的时候会把事件源组件作为一个成员属性,这样在事件监听器中,我们可以通过event来操作事件源组件。

在mxml中设定事件属性值的方式叫做事件监听器内建。这种方式适合应用在简单的事件处理上。如果遇到需要多个事件监听器联合使用等复杂的事件处理情况,则需要应用flex的事件注册。

1.5.2  flex事件监听器注册

flex的可视化组件对象都继承了eventdispatcher类,因此它们都支持事件注册方法addeventlistener。该方法的定义如下:

addeventlistener(type:string, listener:function,
usecapture:boolean = false, priority:int = 0,
useweakreference:boolean = false):void

通过addeventlistener方法,我们可以为可视化组件注册一个事件监听器。type参数表明事件监听器的类型,如鼠标单击事件(mouseevent.click);listener参数是事件监听器的具体方法;usecapture参数设定是否在事件的捕获阶段就进行响应;priority参数设定事件监听器的优先级;useweakreference参数设定事件监听器方法是否为弱类型,一个强类型的事件监听器方法是不会被flex进行自动垃圾收集的。

先前我们提到的事件监听器内建方式,实际上已经创建了一个默认的事件监听器方法,并把actionscript脚本的内容写入方法,但这种方法的最大不足就是无法操作一个以上的事件监听器。

而使用addeventlistener方法注册事件监听器的方式,我们可以控制事件响应的捕获方式和优先级;当我们已经添加的事件监听器在程序的运行过程中需要取消掉的时候,我们可以通过removeeventlistener方法来实现。而这些功能在事件监听器内建方式中不会被支持,理由也很明了:内建的事件监听器都是匿名的,我们无法引用到匿名监听器的监听实体方法。

因此,在使用flex事件机制的时候,还是应该尽量选用事件监听器注册的方式来构建事件处理,这将为事件交互处理带来更多的可扩展性。

|||

1.6  使用adobe flex builder

诚然,我们通过ultraedit、editplus甚至记事本都可以完成mxml及actionscript的编写工作,然而作为一个偏重于界面设计的程序设计语言,成熟的集成开发环境(integrated develop environment,ide)是必不可少的,在处理大量的界面元素以及对程序的编译错误排查时,有一个好的ide更可以达到事半功倍的效果。

adobe在发布flex的同时就发布了一个高效的ide——flex builder,对flex的开发提供了强大的支持。需要注意的是,flex builder是一款商业的ide,从网上下载可以获得30天的免费试用期,之后需要付费才能使用。

flex builder 3属于flex 3产品集,是一款基于eclipse的ide,通过flex builder 3可以高效地完成mxml、actionscript以及flex charting的设计和编写,快速创建各种flex项目及应用程序。

不仅如此,flex builder 3还支持adobe的新一代ria开发平台adobe integrated runtime,即air。air是基于桌面系统的ria开发技术和运行时环境,实现了web应用的桌面化。通过air,我们可以使用现有的web开发技术开发出界面效果更加绚丽多彩的桌面应用程序,如flash/flex/actionscript、html/css/javascript、ajax等技术都可以在air下发挥作用。flex builder 3提供了air的开发,其开发方式和特点与flex开发是完全一致的。

关于air开发的详细介绍可阅读本书的第四部分。

flex builder 3支持windows和macintosh系统,同时由于基于eclipse,flex builder 3的安装版本分为独立安装和插件安装两种。在此,推荐已经装有eclipse的开发者使用插件安装的方式进行安装,一方面避免了eclipse及jre的重复安装,另一方面是支持javaee的企业级开发和flex开发更好的结合。

在安装插件版本的时候注意设定正确的eclipse路径位置,以保证flex builder 3的正确运行,安装过程如图1.8所示。在“please choose an existing eclipse folder: ”下方的文本框中填写eclipse的路径。

图1.8  插件版flex builder 3的安装过程

eclipse是一款强大的集成开发环境和模型平台,eclipse早期只能支持java语言的开发,后来c/c++、uml、ruby等语言都在eclipse平台的基础上实现了定制的集成开发环境,adobe的flex也是一样。flex builder基于eclipse,因此有eclipse开发经验的开发者上手非常容易,而对于新手来说flex builder带来的是规范和广泛应用的强大集成开发环境平台,熟悉flex builder后对eclipse平台也能有所了解。

1.6.1  flex builder系统需求

相对于单纯的flex sdk,flex builder对系统的配置要求更高一些,尤其是对处理器和内存的需求增大。

(1)   flex builder 3(包含sdk和charting组件) windows平台需求如下。

  • 处理器:intel pentium 4处理器
  • 内存需求:1gb ram
  • 硬盘需求:500mb可用硬盘空间
  • 操作系统:microsoft windows xp with service pack 2,windows xp professional,windows 2000 server,windows 2000 professional或windows server 2003
  • java平台:java virtual machine: sun jre 1.4.2,sun jre 1.5,ibm jre 1.5
  • eclipse:eclipse 3.1~3.2

(2)   flex builder 3(包含sdk和charting组件)macintosh平台需求如下。

  • 处理器:1.25ghz powerpc g4~g5或intel系列处理器
  • 内存需求:1gb
  • 硬盘需求:500mb可用硬盘空间
  • 操作系统:mac os x v.10.4.7 or 10.4.8
  • java平台:java virtual machine: sun jre 1.5
  • eclipse:eclipse 3.2(仅支持插件方式安装)

从上述需求可以看出,要使用flex builder,必须有java平台的支持,使用插件方式安装则需要eclipse,因此安装过程较常见的ide要复杂一些,需要注意java和eclipse的版本匹配等问题,推荐使用windows平台开发,使用java se 1.5版本和eclipse 3.2版本。

java和eclipse的资源下载,可以从下列网站获得。

  • sun java官方网站:http://java.sun.com/
  • eclipse官方网站:http://www.eclipse.org/

1.6.2  使用flex builder进行开发

flex builder的主要界面都沿用了eclipse的模型。在flex builder 3中,我们可以新建一个flex项目,如图1.9所示。

图1.9  新建flex项目

暂时可以使用默认方式创建flex项目,将其命名为“hellowbuilder”,确认之后就进入了flex的开发环境。如图1.10所示,这是一个flex develop视图的eclipse界面,创建了hellowbuilder项目,flex builder自动创建了一个hellowbuilder.mxml文件,并加入了mxml的基本代码。当我们完成程序设计时,只需右击导航器中的mxml文件并在run as 菜单条目中选择flex application命令即可运行程序,在debug as菜单条目中选择flex application命令则可以进行程序的跟踪调试。各功能区域的作用如下。

  • 菜单栏:ide支持的所有开发功能菜单。
  • 工具栏:菜单栏中某些常用条目的快捷方式。
  • 导航器:可以按照不同模式浏览当前项目的文件结构。
  • 编辑区:代码编写区域。
  • 定制视图:可以显示控制台、搜索窗口、调试窗口等信息。
  • 大纲:显示当前代码的组织结构。

图1.10  adobe flex builder 3的界面(点击放大)

1.6.3  flex builder开发特点

flex builder对于mxml界面设计的支持是相当强大的,支持“所见即所得”的开发方式。mxml本身就是由标签语言配置而成,因此我们对于mxml的操作方式更适合于配置和设计。同时,在mxml中我们会常常进行调用actionscript脚本、调用自定义组件、做数据绑定等操作,flex builder对这些方面都提供了完善的支持。

flex builder对于mxml的开发提供了两种模式。在flex builder的编辑区上方可以看到source和design按钮。source为代码编辑模式,我们可以手工书写mxml代码,完成actionscript的编写;design为ui设计模式。当我们切换到ui设计状态后,即切换到ui设计界面,如图1.11所示。各功能区域的作用如下。

1. ui设计器

通过所见即所得的方式设计图形界面。

2. 组件工具栏

可以从中选取各种flex可视化组件,放到ui设计器中。

图1.11  flex builder的设计界面(点击放大)

3. 属性编辑区

编辑选定flex可视化组件的各种属性。

设计界面的使用非常简单,我们可以从组件工具栏里看到所有可用的界面或数据组件,可以直接拖放到ui设计器,并通过属性编辑区来设定组件的属性。同时在开发过程中在编辑状态和设计状态灵活切换。

我们回头看看第一个hello world示例,如果使用flex builder将如何完成。

  1. 切换flex builder的开发状态为“design”。
  2. 添加一个panel组件到ui设计器,然后在属性编辑区,设定title的属性为“flex mxml test”。
  3. 添加一个label组件到panel组件(拖放过程中会有蓝色直线定位提示),在属性编辑区,设定text属性为“hello world. 世界,你好!”。

如图1.12所示,我们通过简单的鼠标拖放操作就完成了这个hello world程序。这种“所见即所得”的开发方式能大幅度地提高界面开发的效率。

另一方面,flex builder对actionscript也提供了强大的支持。flex builder中包含着完整的flex sdk,因此对actionscript的各项特性支持都非常完善,并且与mxml的结合也非常紧密。

在处理包结构时,可以直接在flex项目下创建对应的文件夹,完成对flex程序中actionscript类的组织。

例如用flex builder编辑示例calculator的程序,可以直接在calculator项目下创建mycontrols文件夹,并打包两个actionscript类文件calculator.as和mybutton.as。在编码过程中,flex builder支持actionscript的快速开发索引,图1.13中mybutton继承了button类,即mybutton可以使用所有的button操作。因此flex builder会索引出button的所有属性和方法,提高了编码的效率。

图1.12  使用flex builder设计完成hello world(点击放大)

图1.13  使用flex builder 3编写actionscript

flex builder沿袭了eclipse体系,大多数eclipse支持的开发配置、快捷键、调试控制、代码重构等方面的优势都被flex builder所支持。flex builder同样支持版本控制软件(cvs),我们可以把mxml代码和actionscript代码都通过cvs进行管理,因此通过flex builder实现大型项目的开发可以达到事半功倍的效果。

|||

 

1.7  在flex中操作xml

xml(extensible markup language,可扩展标记语言)常用于数据描述、数据封装和数据结构化处理。xml提供了简单和易读的数据组织方式,可以更加方便和标准地对数据进行读取、传输和操作。flex技术中使用的mxml也是基于xml的一种标签规范。

1.7.1  xml在flex中的应用

在flex中处理xml数据需要理解一些基本的xml概念。在本书中会涉及到的xml概念如下。

1. 元素

元素是xml数据中的一个数据条目,通过一对标签和标签内的子元素定义。xml的元素中可以包含文本数据或其他的元素,也可以为空。

2. 空元素

空元素是不包含子元素的xml元素。通常xml的空元素可以写成自封闭的格式,例如<emptyitem/>。

3. 文档

文档是一个独立的xml结构。一个xml文档可以包含任意数量的xml元素,但是必须只包含唯一的根元素。

4. 节点

节点和元素的意义相同。

5. 属性

属性是对标签内的一个xml元素条目的命名。通过 属性名=“值”的格式进行定义。可以看作是位于元素内部的子元素。

flex为处理xml提供了必要的支持,actionscript类xml和xmllist用于建立flex的xml对象。xml类用于描述单一的xml对象,如xml的一个节点数据以及这个节点的所有attribute值和下级节点信息;xmllist类用于描述一组xml元素,这组元素需要有相同的xml标签,通过xmllist可以灵活地对xml元素集合进行添加、删除、修改和查询操作。

通过mxml我们可以使用<mx:xml>标签和<mx:xmllist>标签构造静态的xml结构。actionscript则可以对mxml的静态xml对象或外部文档进行各种数据处理操作,对于大部分xml数据的处理操作都是通过actionscript完成。

通常actionscript可以完成下列关于xml的操作:

  • 构建xml文档,添加xml元素和值。
  • 访问xml元素,属性(attribute)和值。
  • 查询xml元素。
  • 遍历xml数据的集合。
  • 进行xml类型和string类型的相互转换。
  • 操作xml命名空间。
  • 读取外部的xml文件。

1.7.2  通过e4x处理xml

我们已经了解到actionscript是基于标准的ecmascript语言规范构建的,因此也沿袭了ecmascript处理xml的api子集ecmascript for xml,简称e4x。e4x包含下列类型用于处理xml:xml、xmllist、qname和namespace。

1. 创建e4x的xml对象

e4x对于xml的支持遵循着简洁性、高聚合性和易用性的设计原则。因此使用e4x并没有很高的难度。首先我们来看看如何用e4x创建xml类型:

var xmldata:xml =
<product>
<item id = "0001">
<name>thinkpad</name>
<price>24000</price>
</item>
<item id = "0001">
<name>thinkpad</name>
<price>24000</price>
</item>
</product>

上述代码创建了一个变量名为xmldata的e4x的xml对象。构建方式是非常简单的,和定义一个简单类型的变量没有任何区别,直接把xml的内容按顺序写在等号右边即可,e4x会在编译actionscript时对xml的合法性进行验证,不合法的xml会在编译过程中报错。

2. 操作e4x的xml类型

e4x的xml对象描述了xml的数据结构、节点、文本节点、属性/属性值、操作指令、注释信息等内容。不包含操作指令和注释信息的xml对象被定义为简单xml对象,在构建xml对象时,可以通过设定下列语句来实现简单对象的创建:

xml.ignorecomments = true;
xml.ignoreprocessinginstructions = true;

包含操作指令和注释信息的xml对象被定义为复杂xml对象,可以通过comments()方法和processinginstructions()方法来处理注释和操作指令内容。

包括上述两个属性,e4x的xml对象共包含5个静态属性,用于初始化设定或定制操作xml的具体格式。属性列举如下。

  • ignorecomments:
    该属性用于指定是否处理xml注释。
  • ignoreprocessinginstructions:
    该属性用于指定是否处理xml操作指令。
  • ignorewhitespace:
    该属性用于指定是否处理xml中的空格符。
  • prettyindent:
    该属性用于指定对tostring()方法是否进行适当缩进。
  • prettyprinting:
    该属性用于指定对toxmlstring()方法是否进行适当缩进。

xml对象结构的解析和处理通过e4x的方法来实现。e4x为xml对象提供了非常完善的方法支持。通过children()、elements()、parent()方法可以引用到xml对象之中的xmllist对象。本书中对e4x的具体api不详细讲解,读者如有需要可参考ecma357用户手册。

3. 操作e4x的xmllist类型

xmllist类型表明这是一个具有相同结构的xml元素集合。xmllist对象同样支持children()、elements()、parent()等针对上下级节点的索引。同时,xmllist对象还支持attribute()、attributes()方法来操作自身的属性信息。