播放新视频时停止所有视频 [英] stop all videos when a new video is played

查看:23
本文介绍了播放新视频时停止所有视频的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要有关 Youtube API 和嵌入视频的帮助.当单击新的 youtube 视频时,我想停止在当前页面上运行的所有 iframe 视频(这里我只拍摄了 3 个,但有几个视频).在某个时间点,应该只运行一个 iframe youtube 视频.我已经通过文档 [https://developers.google.com/youtube/js_api_reference][1] 并且能够写到这里......

I need some help with Youtube API and embeded videos. I want to stop all iframe videos (here i have taken only 3, but there are several videos)running on the current page when a new youtube video is clicked. At one point of time, only one iframe youtube video should run. I have gone thruogh documentation [https://developers.google.com/youtube/js_api_reference][1] and was able to write till here...

更新:

<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script type="text/javascript" src="http://www.youtube.com/player_api"></script>
        <script type="text/javascript">
            var player;
             function onYouTubeIframeAPIReady() {
                player = new YT.Player('player', {
                    events: {
                        'onReady': onPlayerReady,
                        'onStateChange': onPlayerStateChange
                    }
                });
            }

            var done = false;
              function onPlayerStateChange(event) {
                if (event.data == YT.PlayerState.PLAYING && !done) {
                    alert("hi5");
                    player1.stopVideo();
                    player2.stopVideo();
                    done = true;
                }
               }
        </script>
    </head>
    <body>
        <div>TODO write content</div>
        <ul class="image-grid" id="list"> 
            <li>
                <iframe id="player" width="385" height="230" src="http://www.youtube.com/embed/erDxb4IkgjM?rel=0&wmode=Opaque&enablejsapi=1;showinfo=0;controls=0" frameborder="0" allowfullscreen></iframe> 
            </li>
            <li>
                <iframe id="player1" width="385" height="230" src="http://www.youtube.com/embed/wSrA5iQGlDc?rel=0&wmode=Opaque&enablejsapi=1;showinfo=0;controls=0" frameborder="0" allowfullscreen></iframe>
            </li>
            <li>
                <iframe id="player2" width="385" height="230" src="http://www.youtube.com/embed/c7b_WLkztXc?rel=0&wmode=Opaque&enablejsapi=1;showinfo=0;controls=0" frameborder="0" allowfullscreen></iframe>
            </li>
        </ul>
    </body>
</html>

更新

  1. onStateChange 事件没有被触发(工作)
  2. 在这个例子中,我有 3 个视频,实际上它有更多的视频,而不是为每个视频编写 onPlayerStateChange ..是否可以为所有视频使用数组..并在函数 onPlayerStateChange 中编写 player[].stopVideo() 和 this.playvideo()..类似的东西..(需要帮助)请看这个小提琴 http://jsfiddle.net/LakshmiV/kn5Sf/请帮忙.

推荐答案

你可以这样做...

为每个 iframe 指定一个类,以便它可以被识别为 youtube 播放器的 iframe.这里我给了yt_players"

Give every iframe a class so that it can be identified as an iframe for youtube player. Here I have given "yt_players"

现在您可以使用以下代码...

Now you can use the below code...

<script type="text/javascript">
    players = new Array();

    function onYouTubeIframeAPIReady() {
        var temp = $("iframe.yt_players");
        for (var i = 0; i < temp.length; i++) {
            var t = new YT.Player($(temp[i]).attr('id'), {
                events: {
                    'onStateChange': onPlayerStateChange
                }
            });
            players.push(t);
        }
    }
    onYouTubeIframeAPIReady();

    function onPlayerStateChange(event) {
        if (event.data == YT.PlayerState.PLAYING) {
            var temp = event.target.a.src;
            var tempPlayers = $("iframe.yt_players");
            for (var i = 0; i < players.length; i++) {
                if (players[i].a.src != temp) 
                    players[i].stopVideo();
            }
        }
    }
</script>

已更新代码...这应该对您有所帮助.

Have updated the code...This should be of help to you.

在此处查看...http://jsfiddle.net/anubhavranjan/Y8P7y/

这篇关于播放新视频时停止所有视频的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆