Flex3.0新特性2----Flex-Ajax Bridge

23.5 使用Flex-Ajax Bridge技术控制Flex应用程序
上一小节中介绍在Flex中如何调用Ajax技术。反之,也可使用Ajax技术控制Flex应用程序。JavaScript程序通过Flex-Ajax Bridge技术可控制Flex应用程序组件及外观。本小节将为读者介绍Flex-Ajax Bridge技术的基础知识和使用方法。

23.5.1 Flex-Ajax Bridge技术简介
Flex-Ajax Bridge技术是Adobe公司提供的一种服务技术。此技术为Ajax技术和Flex技术建立起特殊的联系。通过Flex-Ajax Bridge技术可达到控制Flex应用程序的效果。例如,单击网页中的按钮,Flex应用程序中新增一个按钮组件。

Flex-Ajax Bridge技术包括一个“FABridge.as”文件和“FABridge.js”文件。“FABridge.as”文件中定义了Flex客户端的各种属性和方法。“FABridge.js”文件定义了JavaScript客户端的各种属性和方法。有关“FABridge.as”文件和“FABridge.js”文件的相关内容将在后续章节中介绍。

Flex-Ajax Bridge技术的源文件包含在Flex Builder 3.0或LiveCycle Data Service 2.5的安装路径下。具体位置为“Flex Builder 3.0安装路径\sdks\moxie\frameworks\javascript\fabridge”或“LiveCycle Data Service 2.5安装路径\resources\FABridge”。

Flex-Ajax Bridge技术使得Flex技术与Ajax技术的交互更加简单快捷。Flex-Ajax Bridge技术最大的特点是可控制Flex应用程序的组件外观,调用Flex应用程序中的方法和函数。

23.5.2 Flex-Ajax Bridge技术的运行原理
Flex-Ajax Bridge技术只包含两个源文件:“FABridge.as”文件和“FABridge.js”文件。通过定义两个不同客户端(Flex客户端和JavaScript客户端)的对应属性和方法,实现不同客户端间的相互调用。

“FABridge.as”类继承EventDispatcher类,同时实现IMXMLObject接口。其主要功能是存储各种Flex组件的属性和方法,为各种方法添加对应的调用名称。“FABridge.as”类中最重要的实现方法为initializeCallbacks方法。

以下是initializeCallbacks方法的定义代码。

public function initializeCallbacks():void

{

if (ExternalInterface.available == false)

{

return;

}

//为js_getRoot方法添加调用名称

ExternalInterface.addCallback("getRoot", js_getRoot);

//为js_getPropFromAS方法添加调用名称

ExternalInterface.addCallback("getPropFromAS", js_getPropFromAS);

//为js_setPropertyInAS方法添加调用名称

ExternalInterface.addCallback("setPropInAS", js_setPropertyInAS);

//为js_invokeMethod方法添加调用名称

ExternalInterface.addCallback("invokeASMethod", js_invokeMethod);

//为js_invokeFunction方法添加调用名称

ExternalInterface.addCallback("invokeASFunction", js_invokeFunction);

//为js_releaseASObjects方法添加调用名称

ExternalInterface.addCallback("releaseASObjects", js_releaseASObjects);

//为js_create方法添加调用名称

ExternalInterface.addCallback("create", js_create);

//为js_releaseNamedASObject方法添加调用名称

ExternalInterface.addCallback("releaseNamedASObject",js_releaseNamedASObject);

//为incRef方法添加调用名称

ExternalInterface.addCallback("incRef", incRef);

//为releaseRef方法添加调用名称

ExternalInterface.addCallback("releaseRef", releaseRef);

}

(57) ExternalInterface类的addCallback方法为指定函数添加调用名称。定义调用名称后就可在JavaScript中调用。例如,在JavaScript语言中使用“getRoot();”语句调用Flex程序中的js_getRoot方法。

(58) addCallback方法只定义调用名称,而不定义参数。所以在调用函数时,参数个数和顺序必须与Flex程序的方法的定义相同。例如,在JavaScript语言中使用“setPropInAS(21,’text’,’aaaaaa’);”语句调用Flex程序中的js_setPropertyInAS方法。

“FABridge.js”文件定义了JavaScript客户端的各种属性和方法。其主要功能是存储JavaScript客户端的属性和数据,并提供连接Flex-Ajax Bridge的接口方法。

使用Flex-Ajax Bridge技术连接Ajax和Flex程序的步骤如下所示。

在MXML文件中添加FABridge组件。

在添加FABridge组件前,需要将FABridge源文件(“bridge”文件夹)复制至工程路径下。

在MXML文件中添加FABridge组件的语法如下所示。

<fab:FABridge xmlns:fab="bridge.*" />

编译MXML文件。

按下Ctrl+F11快捷键,编译运行MXML程序。

新建HTML网页。

在新网页中添加对Flex应用程序(SWF文件)的引用。

Flex Builder 3在编译MXML文件时会自动生成SWF文件并嵌套于同名的HTML网页中。用户可将其中嵌套SWF文件的代码复制至新网页,但要注意SWF文件的位置。

网页中嵌套SWF文件的语法如下所示。

<object id='SWF程序id'

classid='clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'codebase='http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,5,0,0' height='高度值' width='宽度值'>

<param name='src' value='SWF程序路径’/>

<embed name='SWF程序id ' pluginspage='http://www.macromedia.com/go/ getflashplayer'

src='SWF程序路径' height='高度值' width='宽度值'/>

</object>

SWF程序id可任意。src参数指明SWF程序的路径。

以下代码嵌套了“main.swf”应用程序。

<object id='faa'

classid='clsid:D27CDB6E-AE6D-11cf-96B8-444553540000' codebase='http: //download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,5,0,0' height='400' width='400'>

<param name='src' value='main.swf’/>

<embed name='faa' pluginspage='http://www.macromedia.com/go/ getflashplayer'

src='main.swf' height='400' width='400'/>

</object>

在object标签中添加flashvars变量。

flashvars变量用以存储Flex-Ajax Bridge实例的名称,是连接Flex应用程序的关键处。其语法如下所示。

<object …>



<param name='flashvars' value='bridgeName=Flex-Ajax Bridge实例的名称'/>

<embed … flashvars='bridgeName= Flex-Ajax Bridge实例的名称'/>

</object>

Flex-Ajax Bridge实例的名称可任意。

以下代码嵌套了“main.swf”应用程序,并添加flashvars变量。

<object id='faa'

classid='clsid:D27CDB6E-AE6D-11cf-96B8-444553540000' codebase='http: //download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,5,0,0' height='400' width='400'>

<param name='flashvars' value='bridgeName=example'/>

<param name='src' value='main.swf’/>

<embed name='faa' pluginspage='http://www.macromedia.com/go/ getflashplayer'

src='main.swf' height='400' width='400' flashvars='bridgeName=example’/>

</object>

在网页中引用“FABridge.js”文件。

在<head>标签下使用<script>标签引用“FABridge.js”文件。

以下代码引用“FABridge.js”文件。

<head>

<script src="bridge\FABridge.js" ></script>

</head>

在JavaScript中调用Flex应用程序。

在完成上述六步后,可在JavaScript中调用Flex应用程序。其语法如下所示。

FABridge.flashvars变量值.root();

(59) flashvars变量存储了Flex-Ajax Bridge实例的名称。

(60) root方法是“FABridge.js”文件中定义的方法,指向“FABridge.as”文件的js_getRoot方法。

以下代码在JavaScript中调用Flex应用程序。

FABridge.example.root();

23.5.3 使用getCompenentID方法获取组件
Flex-Ajax Bridge技术中使用getCompenentID方法获取组件。getCompenentID并不是确定的方法名,而表示“get”字符串连接组件id字符串。例如,Flex应用程序中定义了名为“myPanel”的组件,那么获取该组件的方法名为“getMyPanel”。需要注意的是,组件id字符串的第一个字母大写。

以下代码使用getCompenentID方法获取组件“myButton”。

//MXML文件



<mx:Button id="myButton" label="test"/>

//HTML文件



<head>

<script src="bridge\FABridge.js"></script>

<script>

function tt()

{

var flexApp=FABridge.example.root(); //指向Flex应用程序

var btn=flexApp.getMyButton(); //获取组件“myButton”

}

</script>

</head>

<body>

<object id="fff"…>

<param name="flashvars" value="bridgeName=example">

<embed … flashvars="bridgeName=example"/>

</object>

</body>

23.5.4 使用getPropertyName方法获取属性值
getPropertyName方法用以获取组件的属性值。与getCompenentID方法一样,getPropertyName方法也不是确定的方法名,而是“get”字符串连接组件属性字符串。

在使用getCompenentID方法获取组件后,可使用getPropertyName方法获取组件属性。

以下代码使用getPropertyName方法获取按钮组件“myButton”的label属性。

var flexApp=FABridge.example.root(); //指向Flex应用程序

var btn=flexApp.getMyButton(); //获取组件“myButton”

alert(btn.getLabel()); //获取label属性值

与getCompenentID方法一样,组件属性字符串的第一个字母大写。

23.5.5 使用setPropertyName方法设置属性值
setPropertyName方法用以设置组件的属性值。与getCompenentID方法一样,setPropertyName方法也不是确定的方法名,而是“set”字符串连接组件属性字符串。

在使用getCompenentID方法获取组件后,可使用setPropertyName方法设置组件属性。其语法如下所示。

组件实例.set属性名(属性值);

以下代码使用setPropertyName方法更改按钮组件“myButton”的label属性。

var flexApp=FABridge.example.root(); //指向Flex应用程序

var btn=flexApp.getMyButton(); //获取组件“myButton”

btn.setLabel("rrrrrrrrrrrrrrrrr"); //设置组件的label属性

与getCompenentID方法一样,组件属性字符串的第一个字母大写。

23.5.6 为组件添加监听事件
Flex-Ajax Bridge技术也可为组件添加监听事件。其语法如下所示。

组件实例.addEventListenner("事件名",JavaScript中的处理函数名);

使用getCompenentID方法获取组件后,可直接调用组件的所有方法(包括addEventListenner方法)。

以下代码使用addEventListenner方法为按钮组件“myButton”添加单击事件的监听。

var flexApp=FABridge.example.root(); //指向Flex应用程序

var btn=flexApp.getMyButton(); //获取组件“myButton”

var callback=function()

{

alert("success");

}

btn.addEventListenner("click",callback);//为按钮组件“myButton”添加单击事件的监听

本程序说明通过Flex-Ajax Bridge技术可在JavaScript中处理Flex组件的事件。这样,可减少Flex应用程序的规模。

23.5.7 调用Flex程序中的函数
由于“FABridge.example.root()”语句指向的是Flex应用程序本身,所以可直接调用Flex程序的函数。

以下代码中调用了Flex程序中的test函数。

//MXML文件

function test():void

{

Alert.show("hello world");

}

//HTML文件

var flexApp=FABridge.example.root();

flexApp.test();

23.5.8 Flex-Ajax Bridge技术控制Flex程序实例
本实例的效果为:在网页中操作按钮或下拉框组件,Flex应用程序的视图变化。

Flex-Ajax Bridge技术控制Flex程序实例的步骤如下所示。

新建Flex工程“Flex-AjaxBridgeExample”。

在工程根目录中添加“bridge”文件夹。

“bridge”文件夹包含Flex-Ajax Bridge源文件。

在工程根目录中添加“image”文件夹。

“image”文件夹存放图片资源(本例中使用了图片组件)。

编写“main.mxml”文件。

“main.mxml”文件中定义了testAlert函数及可视化组件。

以下代码是“main.mxml”文件的MXML代码。

<?xml version="1.0" encoding="utf-8"?>

<mx:Applicationxmlns:mx="http://www.adobe.com/2006/mxml"layout="absolute"xmlns:bridge="bridge.*"fontSize="13">

<mx:Script>

<![CDATA[

import mx.controls.Alert; //引用 Alert类

public function testAlert():void

{

Alert.show("Hello World!"); //提示"Hello World!"

}

]]>

</mx:Script>

<fab:FABridge xmlns:fab="bridge.*"/> <!--Flex-Ajax Bridge组件-->

<mx:Panel id="myPanel" width="400" height="350" verticalGap="1" title= "Flex-Ajax Bridge实例">

<mx:HBox width="100%" horizontalAlign="center">

<mx:VBox id="myVbox"/>

<!--图片组件-->

<mx:Image id="myImage" width="300" height="300" source="image/ dog.jpg"/>

</mx:HBox>

</mx:Panel>

</mx:Application>

“main.mxml”文件的外观效果如图23-10所示。

按下Ctrl+F11快捷键,编译运行程序。

在工程的“bin”文件夹下新建“FABridge Example.html”文件。

“FABridgeExample.html”文件中定义了一个“创建按钮”按钮和一个下拉框组件。单击“创建按钮”按钮,调用createFlexButton函数来为Flex应用程序新增一个按钮。更改下拉框组件数据时,调用selectChange函数修改Flex应用程序中的图片组件。

以下代码是“FABridgeExample.html”文件的定义代码。

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=”gb2312" />

<script src="bridge\FABridge.js" ></script>

<script language='javascript'>

function createFlexButton()//创建按钮处理函数

{

var flexApp=FABridge.example.root(); //通过FABridge指向Flex应用程序

//创建按钮

var btn=FABridge.example.create("mx.controls.Button");

btn.setWidth(70); //设置按钮宽度

btn.setHeight(25); //设置按钮高度

btn.setLabel("test"); //设置按钮标签

var callback=function() //定义callback函数

{

flexApp.testAlert(); //调用Flex应用程序的testAlert函数

alert("Hello"); //调用JavaScript的提示函数

}

btn.addEventListener("click",callback); //为按钮的单击事件添加处理函数

flexApp.getMyVbox().addChild(btn); //添加按钮到Flex应用程序

}

function selectChange() //下拉框数据变化处理函数

{

var flexApp=FABridge.example.root();//通过FABridge指向Flex应用程序

//设置Flex应用程序图片组件的source属性

flexApp.getMyImage().setSource(imgSelect.value);

}

</script>

<title>Flex-Ajax Bridge 实例</title>

</head>

<body>

<div >

<label>选择图片:</label>

<select name="imgSelect" οnchange="selectChange()"> <!--下拉框-->

<option value="image\dog.jpg">dog.jpg</option>

<option value="image\fruit1.jpg">fruit1.jpg</option>

<option value="image\fruit2.jpg">fruit2.jpg</option>

<option value="image\flower.jpg">flower.jpg</option>

</select>

<br/><br />

<input type="button" onClick="createFlexButton()" value="创建按钮" />

</div>

<div>

<script>

document.write("<object

id='flexApp'

classid='clsid:D27CDB6E-AE6D-11cf-96B8- 444553540000' codebase='http://download.macromedia.com/pub/shockwave/cabs/ flash/swflash.cab#version=8,5,0,0'

height='350' width='400'>");

document.write("<param name='flashvars' value='bridgeName= example'/>");

document.write("<param name='src' value='main.swf'/>");

document.write("<embed

name='flexApp'

pluginspage='http://www.macromedia.com/go/ getflashplayer'

src='main.swf' height='350' width='400'

flashvars='bridgeName=example'/>");

document.write("</object>");

</script>

</div>

</body>

</html>

(61) 要使用Flex-Ajax Bridge技术,有两处代码必不可少。一处为引用“FABridge.js”文件,一处为<object>标签中添加flashvars变量。

(62) 单击Flex应用程序中新增的按钮时,将调用Flex程序的testAlert函数和JavaScript语言中的alert函数。

保存“FABridgeExample.html”文件后,使用浏览器打开此文件。

实例运行前效果和运行后效果如图23-11、图23-12所示。



图23-11 实例运行前效果 图23-12 实例运行后效果

23.6 小结
本章以实例的形式介绍了一些Flex 3.0新特性的应用。由于本书篇幅有限,不能一一介绍新特性。但本章介绍的新特性均为实用的、有代表性的特性,包括加载PDF文件、使用本地SQL数据库、升级AIR应用程序、集成Ajax技术等。通过本章的学习,读者能了解并掌握Flex 3.0的一些新特性,从而开发出功能更加丰富的RIA应用程序。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值