我现在安静的绝望了。
我正在尝试与其他许多人一起使用外部界面来处理我的页面。 无论我做什么或如何以正确的方式更改代码,我总是从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加载顺序问题,我尝试了很多组合,以便调用函数或文档中的文件放在哪里,但也没有运气!
我检查了其他用户关于该问题的大多数条目并尝试了它们,但仍然无效! 我感谢任何想法或提示:)!
来自德国柏林的祝福!
答案 0 :(得分:0)
确保您的脚本被拉入页面,一种方法是使用Chrome调试器/ FireFox Firebug中的“来源”标签并搜索该文件。
确保在包含jQuery之后已经包含了脚本,因为它肯定取决于它。
确保您只包含一个jQuery库。包含多个版本可能会导致问题。
如果有其他库覆盖$
,那么您的代码无效,因为$
不再是jQuery
的别名。您可以使用jQuery.noConflict()
来避免与使用相同变量$
的页面上的其他库发生冲突。