这篇文章将为大家详细讲解有关AS3和JS如何实现通信,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
运行环境:需要安装IIS,创建网站目录
AS3和外部容器通信方法比较简单:
import flash.text.TextField; var txt:TextField = new TextField(); this.addChild(txt); txt.text = "等待..."; //向JS注册方法,JS调用as3Function这个方法,就是执行callback这个方法 ExternalInterface.addCallback("as3Function",callback); function callback($param:String):void { txt.text = $param; } //直接调用SJ的方法getReady ExternalInterface.call("getReady");
注意:先调用ExternalInterface.addCallback,再调用ExternalInterface.call
JS代码:
<html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>FLASH与JS交互</title> <script language="JavaScript"> var jsReady = false; function pageInit() { jsReady = true; } /**页面没有加载完成会返回false,flash需要再次调用此方法*/ function getReady() { if(jsReady) { //as3Function方法是flash注册的方法 getSwfInstance("FlashID").as3Function("成功"); } else { return jsReady; } } /**获取flash,这里注意:<embed>元素name属性是获取的根据*/ function getSwfInstance(name) { if (navigator.appName.indexOf("Microsoft") != -1) { return window[name]; } else { return document[name]; } } </script> </head> <body onLoad="pageInit()"> <object id="flash" classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" width="550" height="400" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0"> <param name="movie" value="test.swf"> <param name="quality" value="high"> <param name="bgcolor" value="#F0F0F0"> <param name="menu" value="false"> <param name="wmode" value="opaque"> <param name="FlashVars" value=""> <param name="allowScriptAccess" value="sameDomain"> <embed id="embedID" src="test.swf" name="FlashID" width="550" height="400" align="middle" quality="high" bgcolor="#f0fff8" menu="false" play="true" loop="false" FlashVars="" allowScriptAccess="sameDomain" type="application/x-shockwave-flash" pluginspage="http://www.adobe.com/go/getflashplayer"> </embed> </object> </body> </html>
注意:swf的文件嵌入到html中的方法比较多,特别关键的要可以获取到所嵌入的swf对象,通过代码你可发现获取swf对象,是通过embed中的name属性。
关于“AS3和JS如何实现通信”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。