【问题标题】:YouTube API starts two videos in the same timeYouTube API 同时启动两个视频
【发布时间】:2016-01-22 17:25:14
【问题描述】:

我有两个由 YouTube api 控制的视频,一切正常,除了页面加载时第一个视频开始(这是正常的)但同时您可以听到第二个视频的声音(这必须开始在第一个视频结束或手动关闭后)如果您暂停第一个视频可以更好地听到...有没有人对此有解决方案?

我认为这是因为两个视频都调用了onReady 事件。

必须在第一个视频结束或关闭时自动启动第二个视频。

<style>
   .second-video {
      display: none;
   }
</style>

<div class="video-site">
  <div class="first-video">
    <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
    <div id="player"></div>
  </div>
  <div class="second-video">
    <div id="player2"></div>
  </div>
</div>

<script src="http://www.youtube.com/player_api"></script>
<script>
  // create youtube player
  var player;
  var player2;

  function onYouTubePlayerAPIReady() {
    player = new YT.Player('player', {
      height: '390',
      width: '640',
      videoId: 'qCDxEif_9js',
      events: {
        'onReady': onPlayerReady,
        'onStateChange': onPlayerStateChange
      }
    });
    player2 = new YT.Player('player2', {
      height: '390',
      width: '640',
      videoId: '43jHG-yH9Gc',
      events: {
        'onReady': onPlayerReady,
        'onStateChange': onPlayerStateChange
      }
    });
  }

  // autoplay video
  function onPlayerReady(event) {
    event.target.playVideo();
    $('.close').click(function(){
      $('.first-video').hide(3000);
      event.target.stopVideo();
      $('.second-video').fadeIn();
    });
  }

  // when video ends
  function onPlayerStateChange(event) {
    if(event.data === 0) {
      $('.first-video').hide(3000);
      $('.second-video').fadeIn();
    }
  }

</script>

http://jsfiddle.net/yjrx8uyz/

【问题讨论】:

  • 是的,两个播放器都触发 onPlayerReady 并播放视频
  • 但是我怎样才能改变这个以使第二个视频仅在第一个视频结束或手动关闭后才开始?

标签: javascript html youtube-api


【解决方案1】:

我更新了你的小提琴http://jsfiddle.net/yjrx8uyz/3/

基本上你必须检查哪个玩家触发了就绪事件和关闭事件。

if(event.target == player)

参考:How to detect when a youtube video finishes playing?

【讨论】:

  • 第二个视频需要在第一个视频结束或关闭时自动启动
  • 另一个重要的事情是第二个视频必须最初隐藏。
  • 只需在脚本开头使用$('.second-video').hide(); .. 或在jquery 准备好的文档上
猜你喜欢
  • 2017-08-30
  • 1970-01-01
  • 2014-08-13
  • 2012-05-26
  • 2013-11-22
  • 2019-07-31
  • 1970-01-01
  • 2014-04-22
  • 2017-07-02
相关资源
最近更新 更多