Flex與JavaScript的交互:調用JavaScipt或者被JavaScript調用

          一、在JavaScript中調用Flex方法
          在Flex中可以用ExternalInterface來調用Flex的方法,途徑是
          1.通過在Flex應用可調用方法列表中添加指定的公用方法。在Flex應用中通過調用addCallback()可以把一個方法添加到此列表中。addCallback將一個ActionScript的方法注冊為一個JavaScript和VBScript可以調用的方法。
          addCallback()函數(shù)的定義如下:
          addCallback(function_name:String, closure:Function):void
          function_name參數(shù)就是在Html頁面中腳本調用的方法名。closure參數(shù)是要調用的本地方法,這個參數(shù)可以是一個方法也可以是對象實例。

          舉個例子:
          <mx:Script>
          ??? import flash.external.*;
          ??? public function myFunc():Number {
          ??????? return 42;
          ??? }
          ??? public function initApp():void {
          ??????? ExternalInterface.addCallback("myFlexFunction",myFunc);
          ??? }
          </mx:Script>

          2.那么在Html頁面中,先獲得SWF對象的引用,也就是用<object .../>聲明的Swf的Id屬性,比如說是MyFlexApp。然后就可以用以下方式調用Flex中的方法。
          <SCRIPT language='JavaScript' charset='utf-8'>
          ??? function callApp() {
          ??????? var x = MyFlexApp.myFlexFunction();
          ??????? alert(x);
          ??? }
          </SCRIPT>
          <button onclick="callApp()">Call App</button>



          二、在Flex中調用 JavaScript
          你可以調用Html頁面中的JavaScript,通過與JavaScript的交互,可以改變Style,調用遠程方法。還可以將數(shù)據(jù)傳遞給Html頁面,處理后再返回給Flex,完成這樣的功能主要有兩種方法:ExternalInterface()和navigateToUrl()。
          在Flex中調用JavaScript最簡單的方法是使用ExternalInterface(),可以使用此API調用任意JavaScript,傳遞參數(shù),獲得返回值,如果調用失敗,F(xiàn)lex拋出一個異常。
          ExternalInterface封裝了對瀏覽器支持的檢查,可以用available屬性來查看。
          ExternalInterface的使用非常簡單,語法如下:
          flash.external.ExternalInterface.call(function_name: String[, arg1, ...]):Object;
          參數(shù)function_name是要調用的JavaScript的函數(shù)名,后面的參數(shù)是JavaScript需要的參數(shù)。
          舉個例子說明如何調用JavaScript函數(shù)
          Flex應用中,添加如下方法:
          <mx:Script>
          <?xml version="1.0" encoding="iso-8859-1"?>
          <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">
          ??? <mx:Script>
          ??????? import flash.external.*;
          ?? ?
          ??????? public function callWrapper():void {
          ??????????? var f:String = "changeDocumentTitle";
          ??????????? var m:String = ExternalInterface.call(f,"New Title");
          ??????????? trace(m);
          ??????? }
          ??? </mx:Script>
          ??? <mx:Button label="Change Document Title" click="callWrapper()"/>
          </mx:Application>
          Html頁面中有如下函數(shù)定義:
          <SCRIPT LANGUAGE="JavaScript">
          ??? function changeDocumentTitle(a) {
          ??????? window.document.title=a;
          ??????? return "successful";
          ??? }
          </SCRIPT>

          posted on 2010-03-05 11:38 飛熊 閱讀(161) 評論(0)  編輯  收藏 所屬分類: Flex

          <2010年3月>
          28123456
          78910111213
          14151617181920
          21222324252627
          28293031123
          45678910

          導航

          統(tǒng)計

          常用鏈接

          留言簿(1)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 佳木斯市| 武安市| 开化县| 肥东县| 南乐县| 清水河县| 木兰县| 邯郸市| 石台县| 庆城县| 江川县| 彩票| 宁国市| 茌平县| 鲁甸县| 昭觉县| 南溪县| 浠水县| 五原县| 博野县| 海晏县| 绿春县| 即墨市| 富锦市| 沙坪坝区| 潮州市| 元江| 宁德市| 保亭| 蕲春县| 陇西县| 平远县| 西丰县| 筠连县| 怀安县| 梨树县| 连江县| 永城市| 旅游| 固安县| 凤阳县|