flex3.0新特性(3)

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" onchange="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应用程序。

你可能感兴趣的:(JavaScript,应用服务器,Ajax,Flex,Flash)