Youtube框架api - 视频无法从开始播放(IE + Chrome问题)

时间:2013-06-23 12:11:14

标签: api youtube youtube-api frame

我的Youtube框架API存在问题。

我的视频的ID为z1gTBVs6zsw。我使用默认的Youtube示例代码(here),结果是(here)。

// 2. This code loads the IFrame Player API code asynchronously.
var tag = document.createElement('script');
tag.src = "//www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);

// 3. This function creates an <iframe> (and YouTube player)
//    after the API code downloads.
var player;
function onYouTubeIframeAPIReady() {
  player = new YT.Player('player', {
    height: '390',
    width: '640',
    videoId: 'z1gTBVs6zsw',
    events: {
      'onReady': onPlayerReady,
      'onStateChange': onPlayerStateChange
    }
  });
}

// 4. The API will call this function when the video player is ready.
function onPlayerReady(event) {
  event.target.playVideo();
}

// 5. The API calls this function when the player's state changes.
//    The function indicates that when playing a video (state=1),
var done = false;
function onPlayerStateChange(event) {
  if (event.data == YT.PlayerState.PLAYING && !done) {
    done = true;
  }
}
function stopVideo() {
  player.stopVideo();
}

问题是视频在IE10 / 9/8和Chrome中以4秒开始播放。在Firefox中没关系。我不知道问题出在哪里。

1 个答案:

答案 0 :(得分:0)

试试这个:

  1. 从onYouTubeIframeAPIReady()
  2. 中删除videoId:'z1gTBVs6zsw'
  3. 将onPlayerReady()替换为:

    function onPlayerReady(event) {
        player.loadVideoById("z1gTBVs6zsw");
    }