admin管理员组文章数量:1410737
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
2 Answers
Reset to default 4Inside 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
本文标签: javascriptYouTube Player APIPlaylist how to get the current video playingStack Overflow
版权声明:本文标题:javascript - YouTube Player API - Playlist how to get the current video playing - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1744853103a2628613.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论