javascript - YouTube Player API - Playlist how to get the current video playing - Stack Overflow

I'm using YouTube Player API Reference for iframethe simple code<div id="player">

I'm using YouTube Player API Reference for iframe the simple code

<div id="player"></div>
<script>
    //Load player api asynchronously.
    var tag = document.createElement('script');
    tag.src = "//www.youtube/iframe_api";
    var firstScriptTag = document.getElementsByTagName('script')[0];
    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
    var done = false;
    var player;
    function onYouTubeIframeAPIReady() {
        player = new YT.Player('player', {
          height: '327',
          width: '530',
          videoId: '_XaWYzsY920',
          playerVars: { 'autoplay': 1,'playlist':['Hzgzim5m7oU', 'QvZIYIVNGZ0']},
          events: {
            'onReady': onPlayerReady,
            'onStateChange': onPlayerStateChange
          }
        });
    }
    function onPlayerReady(evt) {
        evt.target.playVideo();
    }
    function onPlayerStateChange(evt) {
        console.log(evt.data);
        console.log(evt.target.getVideoUrl());
    }
</script>

I thought to work out with evt.data == 5 but it's never fired so ......

Is there is way ?

I'm using YouTube Player API Reference for iframe the simple code

<div id="player"></div>
<script>
    //Load player api asynchronously.
    var tag = document.createElement('script');
    tag.src = "//www.youtube./iframe_api";
    var firstScriptTag = document.getElementsByTagName('script')[0];
    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
    var done = false;
    var player;
    function onYouTubeIframeAPIReady() {
        player = new YT.Player('player', {
          height: '327',
          width: '530',
          videoId: '_XaWYzsY920',
          playerVars: { 'autoplay': 1,'playlist':['Hzgzim5m7oU', 'QvZIYIVNGZ0']},
          events: {
            'onReady': onPlayerReady,
            'onStateChange': onPlayerStateChange
          }
        });
    }
    function onPlayerReady(evt) {
        evt.target.playVideo();
    }
    function onPlayerStateChange(evt) {
        console.log(evt.data);
        console.log(evt.target.getVideoUrl());
    }
</script>

I thought to work out with evt.data == 5 but it's never fired so ......

Is there is way ?

Share Improve this question edited Feb 8, 2013 at 16:00 Russ Ferri 6,5992 gold badges23 silver badges24 bronze badges asked Feb 8, 2013 at 15:47 WhisherWhisher 32.8k34 gold badges127 silver badges204 bronze badges 2
  • Your code seems to work as expected. Do you get any error/warning in console? – Salman Arshad Commented Feb 8, 2013 at 16:27
  • The code works but I don't find the way to catch the playing current video I'd like to point it out on a list just aside the player. – Whisher Commented Feb 8, 2013 at 17:14
Add a ment  | 

2 Answers 2

Reset to default 4

Inside onPlayerStateChange grab the video URL using evt.target.getVideoUrl() then extract the video id using regex:

function onPlayerStateChange(evt) {
    if (evt.data == YT.PlayerState.PLAYING) {
        var url = evt.target.getVideoUrl();
        // "http://www.youtube./watch?v=gzDS-Kfd5XQ&feature=..."
        var match = url.match(/[?&]v=([^&]+)/);
        // ["?v=gzDS-Kfd5XQ", "gzDS-Kfd5XQ"]
        var videoId = match[1];
    }
}
var videoId = evt.target.getVideoData().video_id

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1744853103a4597245.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信