jquery flash externalinterface

时间:2013-03-11 09:27:16

标签: javascript jquery flash externalinterface

我现在安静的绝望了。

我正在尝试与其他许多人一起使用外部界面来处理我的页面。 无论我做什么或如何以正确的方式更改代码,我总是从firefox或chrome获取'没有方法'报告!

我试图通过jQuery在HTML中使用'play'链接触发Flash中的播放功能。我无法弄清楚,出了什么问题!

Flash CS6中的AS3.0(播放声音文件 - Flash内部没问题,播放正常):

import flash.external.ExternalInterface;

ExternalInterface.addCallback("playMusicJS", playMusic);

function playMusic(evt:MouseEvent):void {
  soundChannel.stop();
  soundChannel = sound.play();
  soundTimer.start(); // volume levels and time
  INSTPlayPause.gotoAndStop(2);
  soundChannel.addEventListener(Event.SOUND_COMPLETE, soundComplete);
  INSTPlayPause.INSTPauseBTN.addEventListener(MouseEvent.CLICK, pauseMusic);
}

Javascript(jQuery):

$(document).ready(function() {
  $('#play').click(function() {
    // var flash = document.getElementById("ASPlayer"); // tried as well - no luck
    var flash = $('#ASPlayer').get(0)
    flash.playMusicJS();
    alert("TEST");
  });
});

和HTML:

<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="350" height="30"     id="ASPlayer" title="Player">
  <param name="movie" value="../_flash/TEST -ExternalInterface-.swf">
  <param name="quality" value="high">
  <param name="wmode" value="opaque">
  <param name="swfversion" value="11.0.0.0">
  <param name="expressinstall" value="../_flash/expressInstall.swf">
  <param name="allowScriptAccess" value="always" />
  <!--[if !IE]>-->
  <object type="application/x-shockwave-flash" data="../_flash/TEST -ExternalInterface-.swf" width="350" height="30" id="ASPlayer" title="Player">
    <!--<![endif]-->
    <param name="quality" value="high">
    <param name="wmode" value="opaque">
    <param name="swfversion" value="11.0.0.0">
    <param name="expressinstall" value="../_flash/expressInstall.swf">
    <param name="allowScriptAccess" value="always" />
    <!-- -->
    <embed src="../_flash/TEST -ExternalInterface-.swf" width="350" height="30" name="ASPlayer" quality="high" wmode="opaque" >
    <!-- -->
    <div>
      <p>Content on this page requires a newer version of Adobe Flash Player.</p>
      <p><a href="http://www.adobe.com/go/getflashplayer"><img src="http://www.adobe.com/images/shared/download_buttons/get_flash_player.gif" alt="Get Adobe Flash player" width="112" height="33" /></a></p>
    </div>
    <!--[if !IE]>-->
  </object>
  <!--<![endif]-->
</object>
<p><a href="#" id="play">play</a></p>
</body>
<script type="text/javascript" src="TEST.js"></script>
</html>

我认为它可能是一个DOM加载顺序问题,我尝试了很多组合,以便调用函数或文档中的文件放在哪里,但也没有运气!

我检查了其他用户关于该问题的大多数条目并尝试了它们,但仍然无效! 我感谢任何想法或提示:)!

来自德国柏林的祝福!

1 个答案:

答案 0 :(得分:0)

  1. 确保您的脚本被拉入页面,一种方法是使用Chrome调试器/ FireFox Firebug中的“来源”标签并搜索该文件。

  2. 确保在包含jQuery之后已经包含了脚本,因为它肯定取决于它。

  3. 确保您只包含一个jQuery库。包含多个版本可能会导致问题。

  4. 如果有其他库覆盖$,那么您的代码无效,因为$不再是jQuery的别名。您可以使用jQuery.noConflict()来避免与使用相同变量$的页面上的其他库发生冲突。