我有一个运行 jQuery 和 SWFObject 的网站。当页面加载时,它会设置 2 秒超时,然后触发 SWFObject 实例来加载电影。当电影结束时,它的播放器回调 JS 以触发另一部电影。另一部电影可以正常加载并播放。当它完成播放时,第二部电影也应该触发另一个回调,但它没有。我认为问题在于,在第二部电影初始化时,它应该清除前一个元素并重置它,以便 SWFObject 可以重用它,即使这是在 DOM 中发生的事情,SWFObject 也不会重用该元素. 我认为这是因为 jQuery 仍然以某种方式保留了该元素,即使它已从 DOM 中删除,当 SWFObject 试图重用它时,它会抛出 IE。
我附上了我的代码,所以也许有人能够发现它不工作的地方,或者如果有人对如何让 jQuery 从 DOM 和 jQuery 对象中清除元素有建议。
代码可能看起来有点杂乱无章,但这是我第一次在 Stack Overflow 上发帖,所以我不知道如何让它以正确格式发布所有代码......
提前致谢!
var Shadow;
var ActorWrapper, VideoWrapper;
var Actor, Video;
var Navigation;
var Flash, Random;
var t;
$(document).ready(function () {
if (jQuery.browser.msie && jQuery.browser.version <= 6) {
$(".Body").supersleight();
};
t = window.setTimeout(function () {
window.clearTimeout(t);
Flash = $("#Flash");
if (Boolean(Flash.val())) {
Shadow = $("#Shadow");
ActorWrapper = $("#ActorWrapper");
Actor = $("#Actor");
VideoWrapper = $("#VideoWrapper");
Video = $("#Video");
Random = $("#Random");
Navigation = $(".Navigation");
VideoWrapper.css({
left: parseInt(($(document).width() - 400) / 2),
top: parseInt(($(window).height() - 300) / 2)
});
IncomingActor();
};
}, 2000);
});
var IncomingActor = function () {
ActorWrapper.css({
display: "block",
height: 325,
left: parseInt((($(window).width() - 714) / 2) - 46),
width: 180
});
swfobject.embedSWF("/Resources/Flash/Player.swf", "Actor", "180", "325", "9", null, {
Path: "Amy-1.flv",
Callback: "Vid",
Buffer: 2,
Width: 180,
Height: 325
}, {
play: true,
loop: false,
quality: "best",
wmode: "transparent",
swliveconnect: true,
allowscriptaccess: "always"
});
Navigation.css({
textAlign: "right"
});
};
var Vid = function () {
$("#Actor").remove();
$("#ActorWrapper").html("<div id=\"Actor\"></div>");
VideoWrapper.css({
display: "block"
});
Shadow.css({
display: "block",
height: $(document).height(),
width: $(document).width()
}).animate({
opacity: 0.6
}, 1000).click(function () {
VideoWrapper.animate({
opacity: 0
}, 500);
t = window.setTimeout(function () {
window.clearTimeout(t);
VideoWrapper.css({
display: "none"
});
Shadow.animate({
opacity: 0
}, 500);
t = window.setTimeout(function () {
window.clearTimeout(t);
Shadow.css({
display: "none"
});
}, 500);
}, 500);
});
swfobject.embedSWF("/Resources/Flash/Player.swf", "Video", "400", "300", "9", null, {
Path: (Random.val() + ".flv"),
Callback: "OutgoingActor",
Buffer: 2,
Width: 400,
Height: 300
}, {
play: true,
loop: false,
quality: "best",
wmode: "transparent",
swliveconnect: true,
allowscriptaccess: "always"
});
VideoWrapper.animate({
opacity: 1
});
Navigation.css({
textAlign: "center"
});
};
var OutgoingActor = function () {
ActorWrapper.css({
left: (parseInt(ActorWrapper.css("left")) + 10)
});
VideoWrapper.animate({
opacity: 0
}, 500);
t = window.setTimeout(function () {
window.clearTimeout(t);
VideoWrapper.css({
display: "none"
});
Shadow.animate({
opacity: 0
}, 500);
t = window.setTimeout(function () {
window.clearTimeout(t);
Shadow.css({
display: "none"
});
}, 500);
}, 500);
swfobject.embedSWF("/Resources/Flash/Player.swf", "Actor", "180", "325", "9", null, {
Path: "Amy-2.flv",
Callback: "RemoveOutgoingActor",
Buffer: 2,
Width: 180,
Height: 325
}, {
play: true,
loop: false,
quality: "best",
wmode: "transparent",
swliveconnect: true,
allowscriptaccess: "always"
});
Navigation.css({
textAlign: "right"
});
};