使用Javascript隐藏/取消隐藏Flash视频

时间:2009-06-28 06:02:46

标签: javascript youtube

我正在尝试在加载页面时加载嵌入的Youtube视频,然后在加载后立即隐藏它。这工作正常,但是当我想让它可见时它会出现一秒然后就会消失。这种情况在Firefox 3.0和Safari 4中都有发生,我还没有在其他任何浏览器中尝试过。

我尝试使用.style.display ='none'然后.style.display =''隐藏它和style.display ='block';让它再次可见,以及尝试使用jQuery .hide()和.show(),但这两种方法都会导致youtube视频在可见后消失。

是否有'正确'的方式我应该制作< object> ...< embed>标签使用javascript隐藏和可见,所以当我试图让它可见时它不会消失?我不只是在需要时动态加载第二个视频的原因是我希望视频开始下载,以便在我准备好让它可见时立即播放。

以下是我的html和javascript代码段:

mute(),play(),stop()只是同名youtube javascript api调用的包装。

switchVideoPlayers()从一个html按钮调用,分别传递1和2作为oldid和newid。

我无法弄清楚我应该将哪些内容作为片段包含在内,所以我将整个页面倾倒在下面:

<html>
<head>
<title>YouTube test</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>

<script>

var player = new Array();
var currentplayer = 1;

function onYouTubePlayerReady(playerid)
{
    if (playerid.indexOf('obj') > -1)
    {
        playerid = playerid.substring(3);
    }

    debug("player " + playerid + " loaded");

    player[playerid] = document.getElementById(playerid);

    if (playerid == 1)
        player[playerid].loadVideoById('5hSW67ySCio');
    else
    {
        player[playerid].loadVideoById('VgMVHc5N3WM', 10); //videoid
        mute(playerid);
        setTimeout(function() { 
            stop(playerid);
            $("#obj" + playerid).hide();
        }, 1000);   

    }
}

function play(id)
{
    player[id].playVideo();
}

function pause(id)
{
    player[id].pauseVideo();
}

function stop(id)
{
    player[id].stopVideo();
}

function mute(id)
{
    player[id].mute();
}

function unmute(id)
{
    player[id].unMute();
}


function seek(id,seconds)
{
    player[id].seekTo(seconds, false);
}

function getCurrentTime(id)
{
    return player[id].getCurrentTime();
}

function loadNewVideo(id,videoid, startseconds)
{
    player[id].loadVideoById(videoid, startseconds);
    mute(id);
    setTimeout(function() { stop(id); }, 1000); 
}

function switchVideoPlayers(oldid, newid)
{
    stop(oldid);
    $("#obj" + oldid).hide();

    $("#obj" + newid).show();
    setTimeout(function() {
        unmute(newid);
        play(newid);
    }, 10);
}

function debug(message)
{
    $('#debug').html($('#debug').html() + message + "<br />");
}


</script>

</head>

<body>

<object id='obj1' width="425" height="344">
<param name="movie" value="http://www.youtube.com/v/5hSW67ySCio&hl=en&fs=1&"></param>
<param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param>
<embed id='1' src="http://www.youtube.com/apiplayer?enablejsapi=1&playerapiid=1" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="344"></embed>
</object>

<object id='obj2' width="425" height="344">
<param name="movie" value="http://www.youtube.com/v/5hSW67ySCio&hl=en&fs=1&"></param>
<param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param>
<embed id='2' src="http://www.youtube.com/apiplayer?enablejsapi=1&playerapiid=2" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="344"></embed>
</object>


<br />
<br />

<input type='button' value='Play' onclick='play(currentplayer);' />
<input type='button' value='Pause' onclick='pause(currentplayer);' />
<input type='button' value='Stop' onclick='stop(currentplayer);' />
<input type='button' value='Mute' onclick='mute(currentplayer);' />
<input type='button' value='UnMute' onclick='unmute(currentplayer);' />
<input type='button' value='Seek' onclick='seek(currentplayer,getCurrentTime(currentplayer) + 10);' />
<input type='button' value='Get Current Time' onclick='alert(getCurrentTime(currentplayer));' />
<input type='button' value='load strain video' onclick='loadNewVideo(currentplayer+1,"VgMVHc5N3WM", 10);' />
<input type='button' value='switch to next video' onclick='switchVideoPlayers(currentplayer,currentplayer + 1);' />

<br />
<br />
<a href='http://code.google.com/apis/youtube/js_api_reference.html'>api</a>

<div id='debug'>DEBUG MESSAGES:<br />
</div>
</body>

</html>

3 个答案:

答案 0 :(得分:3)

大多数浏览器会像这样对待Flash - 当你隐藏+显示它时,它会重新初始化swf。

如果您不希望它重新初始化,您可以将其移开(绝对位置) - 类似于-9999px之类的东西,然后在您想要显示它时将其移回原位。

答案 1 :(得分:0)

再看看这个,结果是当视频可见时再次调用onYouTubePlayerReady()函数。在这个函数中,隐藏视频播放器的代码再次被调用,这就是它消失的原因。

答案 2 :(得分:0)

在大多数浏览器中,您可以通过设置css样式visibility: hidden;

来避免重新初始化问题

这有点令人讨厌,因为flash电影仍然在页面流中占据相同的位置,但它会保持swf不可见,并有助于缓解闪光显示通过叠加(如灯箱)等问题

在Opera上,隐藏的swf停止响应通过ExternalInterface.addCallback向javascript公开的函数,因此这个解决方案可能因上述任何原因而无法接受。