天天看點

積少成多Flash(8) - ActionScript 3.0 網頁之擷取參數,JavaScript與ActionScript之間的互相調用

<a href="http://webabcd.blog.51cto.com/1787395/342175" target="_blank">[索引頁]</a>

<a href="http://down.51cto.com/data/100162" target="_blank">[源碼下載下傳]</a>

積少成多Flash(8) - ActionScript 3.0 網頁之擷取參數,JavaScript與ActionScript之間的互相調用

介紹

示範使用 Flash ActionScript 3.0 擷取配置參數,頁面參數,以及 js 與 as 間的互動 

參數擷取 - 通過 Application.application.stage.loaderInfo.parameters[param] 擷取配置參數(flashVars);通過 JavaScript 擷取 url 參數

與JavaScript互動 - 利用 ExternalInterface 實作 ActionScript 和 JavaScript 間的互相調用

Flash 端

Main.as

/* 

* 注:    

* 1、如果需要 Flash 與 JavaScript 互動,那麼包含 swf 檔案的 html 标記必須要有 id 

* 2、如跨域調用,需要設定相關的插件參數,如 &lt;param name="allowScriptAccess" value ="always" /&gt; 

* 3、Flash端的相關安全類配置:類似 flash.system.Security.allowDomain("*"); 

*/ 

package    

        import flash.display.MovieClip; 

        import flash.external.ExternalInterface; 

        public class Main extends MovieClip 

        { 

                public function Main():void 

                { 

                        loadVarsDemo(); 

                        asCallJS(); 

                        jsCallAS(); 

                } 

                // 擷取頁面端配置的參數 

                // 下面的示例用于讀取頁面端的如下配置    

                // &lt;param name="flashVars" value="name=webabcd&amp;age=29" /&gt; 

                // &lt;param name="movie" value="Demo.swf?dateOfBirth=1980-02-14" /&gt; 

                private function loadVarsDemo():void 

                        lblVars.text =    

                                "姓名:" + stage.loaderInfo.parameters["name"] 

                                + "    " 

                                + "年齡:" + stage.loaderInfo.parameters["age"] 

                                + "生日:" + stage.loaderInfo.parameters["dateOfBirth"]; 

                        lblSwfUrl.text = stage.loaderInfo.url; 

                // ActionScript 調用 JavaScript 

                private function asCallJS():void 

                        // 調用指定的 JavaScript 端的函數,并順序指定傳遞給 JavaScript 端函數的參數 

                        ExternalInterface.call("jsMethod", "param1", "param2"); 

                // JavaScript 調用 ActionScript 時,ActionScript 端的函數 

                private function jsCallAS():void 

                        // 注冊一個需要被 JavaScript 調用的函數 

                        ExternalInterface.addCallback("asMethod", output);        

                public function output(p1:String, p2:String):void 

                {        

                        lblResult.text = "參數1:" + p1 + " 參數2:" + p2 

                }     

        } 

}

Web 端

Demo.html

&lt;html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh_cn" lang="zh_cn"&gt; 

&lt;head&gt; 

&lt;meta http-equiv="Content-Type" content="text/html; charset=gb2312" /&gt; 

&lt;title&gt;Demo&lt;/title&gt; 

&lt;script language="javascript"&gt;AC_FL_RunContent = 0;&lt;/script&gt; 

&lt;script src="AC_RunActiveContent.js" language="javascript"&gt;&lt;/script&gt; 

&lt;/head&gt; 

&lt;body bgcolor="#ffffff"&gt; 

&lt;script type="text/javascript"&gt; 

        Request = { 

                // 根據指定的名稱取 url 參數值 

                QueryString : function(name){ 

                     var svalue = location.search.match(new RegExp("[\?\&amp;]" + name + "=([^\&amp;]*)(\&amp;?)","i")); 

                     return svalue ? svalue[1] : svalue; 

                }, 

                // 取 url 參數字元串 

                Query : function(){ 

                     var svalue = location.search.match(new RegExp("[\?](.*)","i")); 

        // 根據指定的名稱取 url 參數值 

        alert(Request.QueryString("param")); 

        // 取 url 參數字元串 

        alert(Request.Query()); 

&lt;/script&gt; 

        // ActionScript 調用 JavaScript 時,JavaScript 端的函數 

        function jsMethod(p1, p2) 

                alert("參數1:" + p1 + " 參數2:" + p2); 

        // JavaScript 調用 ActionScript 

        window.onload = function() 

                var swfObj = document.getElementById('Demo');        

                // asMethod 為 ActionScript 端注冊的可被 JavaScript 調用的函數 

                swfObj.asMethod("param1", "param2"); 

&lt;object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0" width="550" height="400" id="Demo" align="middle"&gt; 

        &lt;param name="allowScriptAccess" value="sameDomain" /&gt; 

        &lt;param name="allowFullScreen" value="false" /&gt; 

        &lt;param name="movie" value="Demo.swf?dateOfBirth=1980-02-14" /&gt; 

        &lt;param name="quality" value="high" /&gt; 

        &lt;param name="bgcolor" value="#ffffff" /&gt;         

        &lt;embed src="Demo.swf" quality="high" bgcolor="#ffffff" width="550" height="400" name="Demo" align="middle"allowScriptAccess="sameDomain" allowFullScreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" /&gt; 

        &lt;param name="flashVars" value="name=webabcd&amp;age=29" /&gt; 

&lt;/object&gt; 

&lt;/body&gt; 

&lt;/html&gt;

OK

     本文轉自webabcd 51CTO部落格,原文連結:http://blog.51cto.com/webabcd/342203,如需轉載請自行聯系原作者

繼續閱讀