我想向Web应用程序添加声音警报。我相信Flash是支持所有主流浏览器的最佳方式,即。 IE,Firefox,Chrome,Safari。 Chrome似乎无法与非闪存声音解决方案配合使用。
我一直在使用jQuery,并希望使用jQuery Sound插件。一个例子显示在jQuery Sound Plug-in Demo,但我无法在IE7和IE8 Beta中使用它。
我在下面的代码部分中遇到了JavaScript问题。
load: function(evt, url) {
var self = $(this);
var id = self.data("sound.settings").id;
var movie = self.data("sound.get_movie")(id);
movie.load(url);
self.data("sound.isPlaying", true);
},
该插件还使用以下功能来获取适用于IE浏览器的Flash电影。
var get_movie = function(id) {
var movie = null;
if ($.browser.msie) {
movie = window[id];
} else {
movie = document[id];
}
return movie;
};
我有什么东西在这里缺少所以这可以在IE7和IE8 Beta中运行吗?任何帮助将不胜感激。
答案 0 :(得分:1)
更改以下代码时,问题已修复:
if ($.browser.msie) {
var html = '<object id="' + settings.id + '" data="' + settings.swf + '" type="application/x-shockwave-flash" width="0" height="0">';
html += ' <param name="movie" value="' + settings.swf + '"/>';
html += ' <param name="AllowScriptAccess" value="always"/>';
html += ' <param name="quality" value="high"/>';
html += ' <param name="wmode" value="transparent"/>';
html += ' <!-- -->';
html += ' </object>';
} else {
var html = '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"';
html += ' codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab" width="0" height="0"';
html += ' id="' + settings.id + '"';
html += ' align="middle">';
html += '<param name="movie" value="' + settings.swf + '" />';
html += '<param name="quality" value="' + settings.quality + '" />';
html += '<param name="FlashVars" value="id=' + settings.id + '"/>';
html += '<param name="allowScriptAccess" value="always"/>';
html += '<embed src="' + settings.swf + '" FlashVars="id='+ settings.id +'"';
html += ' allowScriptAccess="always" quality="' + settings.quality + '" bgcolor="#ffffff" width="0" height="0"';
html += ' name="' + settings.id + '" align="middle" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" />';
html += '</object>';
}
...
var get_movie = function(id) {
var movie = null;
if ($.browser.msie) {
//movie = window[id];
movie = document.getElementById(id);
} else {
movie = document[id];
}
return movie;
};
来源参考:SoundManager 2