[js] flash如何与js交互?
生活随笔
收集整理的這篇文章主要介紹了
[js] flash如何与js交互?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
[js] flash如何與js交互?
當Flash置于HTML容器中時,經常會遇到AS與JS的通信問題,例如:JS能否調用AS中的變量、方法,AS能否調用JS中的變量、方法等等。答案是肯定的。隨著技術的不斷發展,解決方案也是多種多樣的。 在我總結的HTML與FLASH之間的“靜態”傳值一文中提到了JS使用SetVariable方法來設置FLASH中的變量,kinglong認為此法已經過時。對此我表示同意,但上文重點畢竟不是在討論JS與AS的通信,因此另外對AS與JS通信做一個個人總結,歡迎大家討論。 實現JS跟AS的通信,目前可選方法比較多,但早期的方法在使用便捷和功能上都不是很完美,下面做一簡要說明:一、getURL getURL("javascript:history.go(-1)");通過URL協議來訪問頁面中的javascript,上面控制瀏覽器歷史的代碼很眼熟吧,諸如此類我們平時在定制頁面收藏,發送郵件時都會經常使用這種方式。雖然你也可以調用頁面中自己定義的JS函數,但我個人認為局限性還是比較大,函數的參數傳遞并不是很靈活,無返回值,而且只能實現AS調用JS,反之不行。二、fscommand命令 使用fscommand來調用AS定義的方法也是一個很常用的方式,但我們需要在HTML頁面中定義一個具有規定格式的myFlash_DoFSCommand函數,首先定義這個函數我個人就覺得麻煩,而且也只能實現AS調用JS,無函數返回值。三、SetVariable 上面兩種方法都只能實現AS調用JS,而SetVariable恰恰相反,只要我們稍微做下處理,他就可以幫我們變相調用AS中的方法。大概思路如下:AS中設置一個狀態變量,并使用Object的watch方法對其監視,JS通過SetVariable來修改這個狀態變量,一旦偵測到了變量的改變,那就可以根據不同的狀態值來選擇執行AS中的相應函數了。如果需要考慮用戶的低版本播放器,那么你可以考慮下該方法,個人認為還是比較靈活的。可以看出上面的這些做法都有一定的局限性,所以在我們的應用中很多時候都不得不將他們結合使用。而下面我要具體介紹的就是 ExternalInterface的做法,通過它你能輕松實現AS與JS的雙向方法調用,從而也解決了雙向的變量訪問,詳細介紹可參見FLASH幫助文檔和Adobe的官方教程,下面用兩個簡單例子來說明ExternalInterface的使用。一、AS調用JS的方法(實例演示)Flash中代碼: //導入包 import flash.external.*; get_btn.onRelease = function(){ //調用頁面中的JS函數 var temp_str = String(ExternalInterface.call("say", "Hello,World")); result_txt.text = temp_str; } Html中代碼:function say(txt){ return txt; }沒錯,就這么簡單,JS函數定義沒有任何要求,AS中使用call方法直接調用就可以了。二、JS調用AS的方法(實例演示)FLASH中代碼://導入包 import flash.external.*; //提供JS訪問的函數名 var _method:String = "say"; //指定本地函數中this變量的作用域,可設置為null留空 var e_area:Object = null; //AS內部函數名 var method:Function = say; //將函數注冊到容器列表 var wasSuccessful:Boolean = ExternalInterface.addCallback(_method, e_area, method); //查看注冊是否成功 if(wasSuccessful){ result_txt.text = "函數注冊成功"; } //本地的函數 function say(txt:String) { result_txt.text = txt; } Html中代碼:<div> <form> <input type="button" οnclick="callExternalInterface()" value="JS調用AS方法" /> </form> <script> function callExternalInterface() { thisMovie("demo").say("Hello,World"); } //瀏覽器兼容訪問DOM function thisMovie(movieName) { if (navigator.appName.indexOf("Microsoft") != -1) { return window[movieName] } else { return document[movieName] } } </script> </div> 其中紅色代碼是核心代碼,其作用原理是AS端通過addCallback函數把AS內部定義的方法注冊為可從容器中調用,允許自定義另外一個方法名供 JS來調用這個方法,函數調用成功返回true,失敗返回flase,在此例中通過wasSuccessful變量來判斷函數是否注冊成功。函數注冊成功以后,JS可以通過DOM來訪問SWF對象,然后直接調用預定義的方法即可。通過比較可以看出,使用ExternalInterface來完成AS和JS的通信,代碼可以更簡潔,更清晰,功能也更強大,不過還有些細節你需要了解,需要使用8.0以上的播放器,對于調用的JS函數不能使用遞歸,同時安全域限制也必須在考慮之中。個人簡介
我是歌謠,歡迎和大家一起交流前后端知識。放棄很容易,
但堅持一定很酷。歡迎大家一起討論
主目錄
與歌謠一起通關前端面試題
總結
以上是生活随笔為你收集整理的[js] flash如何与js交互?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【电力电子技术AC-DC】三相桥式晶闸管
- 下一篇: Excel数据透视表经典教程三《数据透视