首页 > 代码库 > js与as3交互的问题

js与as3交互的问题

我想,是时候纠正一定以来的误区了,那就是html中的js如何获取flash的swf对象,并与as3交互。

按照官方的写法应该是在 Internet Explorer 中返回 object 标签的 id 属性,或者在 Netscape 中返回 embed 标签的 name 属性(AS3 API手册)。

function thisMovie(movieName) {   if (navigator.appName.indexOf("Microsoft") != -1) {        return window[movieName];   } else {        return document[movieName];   }}

但这种写法是有问题的,特别是后期的Firefox,如果object里面内嵌embed标签,它一定是返回embed对象(这个对象是function形式),而embed是无法取得as3的addcallback方法的。因此网上有很多人在叫ff里面js无法与as3交互,事实并非如此。

我对几个浏览器经过测试后,发现它们对window[id]与document[name]的兼容性如下

1

使用html代码:

<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"             id="ExternalInterfaceExample" width="500" height="375"             codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab">         <param name="movie" value="ExternalInterfaceExample.swf" />         <param name="quality" value="high" />         <param name="bgcolor" value="#869ca7" />         <param name="allowScriptAccess" value="sameDomain" />         <embed src="ExternalInterfaceExample.swf" quality="high" bgcolor="#869ca7"             width="500" height="375" name="ExternalInterfaceExample" align="middle"             play="true" loop="false" quality="high" allowScriptAccess="sameDomain"             type="application/x-shockwave-flash"             pluginspage="http://www.macromedia.com/go/getflashplayer">         </embed>     </object>

ie8是升级以后的版本。

可以看到,使用document[id]所有浏览器都可以取得swf对象,但ff与opera不能取得as3向外暴露的方法。而使用window[name]则chrome/opera/safari不能取得as3的addcallback方法。如果兼容这两种方法opera还是不能取得as3的方法(其实并非Opera无法取得embed元素,而是这两种写法不凑效,如果使用$("embed[name=‘swfImg‘]")[0]一样是可以获取swf对象的,只是无法action交互)。里面最大的亮点是ie,无论使用哪种方法都能取得对象并与as3交互。

如果使用我们常用的document.getElementById呢,结果非常诧异

2

所有浏览器都能取得object标签对象,并且都能取得as3暴露的addcalback方法。

我们再来看第一表中的浏览器,能够取得Embed标签的是firefox/chrome/opera/safari浏览器,这几种浏览器都是更新换代非常快,平滑升级的现代浏览器。既然它们都支持object标签,因此无须担心是否需要嵌入Embed对象。

如果把Embed标签去掉,写法变成

<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"             id="ExternalInterfaceExample" width="500" height="375"             codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab">         <param name="movie" value="ExternalInterfaceExample.swf" />         <param name="quality" value="high" />         <param name="bgcolor" value="#869ca7" />         <param name="allowScriptAccess" value="sameDomain" />     </object>

结果

3

实际上,Embed标签并非html 4.01的标准标签,但很多浏览器都支持,只是支持的程度不同。在html5中,Embed已经成为了一种标准,它可以嵌入视频、音频和Flash,但在ipad等一些设备中是无法播放Flash的,Object标签也不行。

所以,如果不考虑向前浏览器兼容的话,只管使用object嵌入Flash就行了,获取Flash元素、交互的话document.getElementById足已。