Flex:JavaScript與ActionScript函數相互調用

來源:互聯網
上載者:User
1、在JavaScript中調用Flex(ActionScript)方法
在Flex中可以用ExternalInterface來調用Flex的方法。
在Flex應用中通過調用addCallback()可以把一個方法添加到列表中。addCallback將一個ActionScript的方法註冊為一個JavaScript和VBScript可以調用的方法。
addCallback()函數的定義如下:
addCallback(function_name:String, closure:Function):void
function_name參數就是在Html頁面中指令碼調用的方法名。closure參數是要調用的本地ActionScript方法,這個參數可以是一個方法也可以是對象執行個體。

例子:
<mx:Script>
    import flash.external.*;
    public function asFunc():String {
        return "Hello Flex";
    }
    public function initApp():void {
        ExternalInterface.addCallback("flexFunctionAlias",asFunc);
    }
</mx:Script>
那麼在Html頁面中,先獲得SWF對象的引用,也就是用<object .../>聲明的Swf的Id屬性,比如說是MyFlexApp。然後就可以用以下方式調用Flex中的方法。
<SCRIPT language='JavaScript' charset='utf-8'>
    function callApp() {
        var x = MyFlexApp.flexFunctionAlias();
        alert(x);
    }
</SCRIPT>
<button >Call App</button>

2、在Flex(ActionScript)中調用 JavaScript(後面有執行個體)
在Flex中調用JS代碼就方便得多。你可以調用Html頁面中的JavaScript,通過與JavaScript的互動,可以改變Style,調用遠程方法。還可以將資料傳遞給Html頁面,處理後再返回給Flex,完成這樣的功能主要有兩種方法:ExternalInterface()和navigateToUrl()。
在Flex中調用JavaScript最簡單的方法是使用ExternalInterface(),可以使用此API調用任意JavaScript,傳遞參數,獲得傳回值,如果調用失敗,Flex拋出一個異常。
ExternalInterface封裝了對瀏覽器支援的檢查,可以用available屬性來查看。
ExternalInterface的使用非常簡單,文法如下:
flash.external.ExternalInterface.call(function_name: String[, arg1, ...]):Object;
參數function_name是要調用的JavaScript的函數名,後面的參數是JavaScript需要的參數。
舉個例子說明如何調用JavaScript函數
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頁面中有如下函數定義:
<SCRIPT LANGUAGE="JavaScript">
    function changeDocumentTitle(a) {
        window.document.title=a;
        return "successful";
    }
</SCRIPT>

應用例子
1。在Flex程式中開啟一個瀏覽器視窗
線上示範 |  源碼下載

//---CallJSApp.mxml

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

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" viewSourceURL="srcview/index.html">

      <mx:Script>

            <![CDATA[

                  import mx.validators.ValidationResult;

                  import cwmlab.util.*;                 

                  private function openBrowser():void

                  {

                        MyURLUtil.openWindow("http://www.google.com/");

                  }                                  

            ]]>

      </mx:Script>

      <mx:HBox width="100%">

            <mx:Button label="open" click="openBrowser()"/>      

      </mx:HBox>     

</mx:Application>

//--MyURLUtil.as

package cwmlab.util

{   

      import flash.external.ExternalInterface;   

      public class MyURLUtil   

      {       

            protected static const WINDOW_OPEN_FUNCTION : String = "window.open";

           

            public static function openWindow(url : String, window : String = "_blank",

                   features : String = "") : void{

                  ExternalInterface.call(WINDOW_OPEN_FUNCTION, url, window, features);       

          }

      }

}// ActionScript file

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.