JS技术

Javascript与Flash通信全解析_Javascript教程

字号+ 作者:H5之家 来源:H5之家 2015-09-17 14:38 我要评论( )

Javascript与Flash通信全解析,学习Javascript与Flash通信全解析,Javascript与Flash通信全解析,查看Javascript与Flash通信全解析,Flash 教程笔记学习 针对于刚开

Flash 教程笔记学习


  针对于刚开始学习flash as3编程笔记,希望对学习者有多帮助;

  Flash已经提供了ExternalInterface接口与JavaScript通信,ExternalInterface有两个方法,call和addCallback,call的作用是让Flash调用js里的方法,addCallback是用来注册flash函数让js调用。下面是官方文档对call和addCallback的说明:

利用 ActionScript,可以在 HTML 页上执行以下操作:

调用任何 JavaScript 函数。
传递任意数量、具有任意名称的参数。
传递各种数据类型(Boolean、Number、String 等等)。
接收来自 JavaScript 函数的返回值。
通过在 HTML 页上使用 JavaScript,可以:

调用 ActionScript 函数。
使用标准的函数调用表示法传递参数。
将值返回给 JavaScript 函数。
实际使用的时候,需要注意以下两点:

    一、调用时机。
  js调用flash对象提供的函数时,可能swf还没有完全加载完,此时调用会失败。类似的,flash调用js函数时,也存在js函数还没load到的情况。所以adobe官方示例里采用了一种比较绕的逻辑来避免这种问题:

页面上有一个变量_isJSReady,初始为false。还有一个isJSReady函数用来返回_isJSReady的值,供flash调用。在合适的时机(例如:window.onload),将_isJSReady设置为true,表示flash可以使用js里的函数了;
flash里有一个定时器,定期(例如:100ms)去调用页面上的isJSReady方法,直到isJSReady返回true,就可以addCallback,调用页面上的flashReadyHandler方法,通知页面可以跟flash交互了。

二、如何获取flash对象。

    将flash插入到页面有很多方法,例如swfobject.js或者AC_RunActiveContent.js类似的库。我们来看一种最原始的方法,直接在html插入标记来插入flash:
 

    <object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"  
    codebase=" 
    /flash/swflash.cab#version=10,0,0,0" width="730" height="520" id="test" align="middle"> 
    <param name="allowScriptAccess" value="sameDomain" /> 
    <param name="allowFullScreen" value="false" /> 
    <param name="movie" value="test.swf" /> 
    <param name="quality" value="high" /> 
    <param name="bgcolor" value="#ffffff" /> 
        <embed src="test.swf" quality="high" bgcolor="#ffffff"  
        width="730" height="520" name="test" align="middle"  
        allowScriptAccess="always" allowFullScreen="false"  
        type="application/x-shockwave-flash"
        pluginspage=""
         /> 
    </object>

假设test.swf提供了hello的方法,我们来在js里调用这个方法,代码如下:

document.getElementById("test").hello();
结果,除了IE之外,其他浏览器都不会工作,会提示找不到hello这个方法。这个问题困扰了我比较久。最后发现:在非IE浏览器里,flash提供的方法是加在embed上的,我们要得到object下的embed对象,调用embed上的方法才会成功!

官方示例是采用下面方法获取flash对象的:

    function getFlashMovieObject(movieName){ 
      if (window.document[movieName]){ 
        return window.document[movieName]; 
      }else if (navigator.appName.indexOf("Microsoft")==-1){ 
        if (document.embeds && document.embeds[movieName]) 
        return document.embeds[movieName]; 
      }else{ 
        return document.getElementById(movieName); 
      } 
    }


这里罗列出所有情况,当然不会有问题。其实,没必要弄得这么复杂,我们给object和embed取不同名称,例如一个test1,一个test2,如果是IE就getElementById(“test1”),其它浏览器getElementById(“test2”)就行了。另外,如果使用js插入swf的话,很可能js里就已经做过判断,根据不同浏览器来输出object和embed其中一种。总之,如果调用失败,首先检查得到的flash对象是不是[object HTMLEmbedElement]。

最后,放上一个例子,是我参照官方文档写的。

点击这里

补充一个细节:在傲游里,刷新页面后js调用flash里的方法可能会失败。这篇文章有提到这个问题,解决方法是给swf地址加上随机数,让浏览器每次都重新加载flash。不过这样swf就不能被浏览器缓存,很无语~下面是一段判断傲游的js代码,建议只针对傲游加随机数。

 

    var isMaxthon = false; 
    try { 
        if (external.max_language_id != undefined){   
            isMaxthon = true; 
        } 
    }catch (e){} 
    alert(isMaxthon); 

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • JavaScript入门教程(二)_javascript教程教程

    JavaScript入门教程(二)_javascript教程教程

    2015-10-10 14:25

  • JavaScript入门教程(五)_javascript教程教程

    JavaScript入门教程(五)_javascript教程教程

    2015-10-10 14:21

  • JavaScript入门教程(四)_javascript教程教程

    JavaScript入门教程(四)_javascript教程教程

    2015-10-10 14:19

  • JavaScript入门教程(三)_javascript教程教程

    JavaScript入门教程(三)_javascript教程教程

    2015-10-10 14:17

网友点评