0

我对 Youtube 框架 API 有疑问。

我的视频有 ID z1gTBVs6zsw。我正在使用默认的 Youtube 示例代码(这里),我的结果是(这里)。

// 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();
}

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

4

1 回答 1

0

try this:

  1. remove the videoId: 'z1gTBVs6zsw' from the onYouTubeIframeAPIReady()
  2. replace onPlayerReady() with:

    function onPlayerReady(event) {
        player.loadVideoById("z1gTBVs6zsw");
    }
    
于 2013-06-23T12:38:49.703 回答