问题是我从gdata / youtube-api嵌入,有时会返回播放 视频限制或嵌入不允许。所以我正在检查一个州或什么的 处理这个。我尝试添加& format = 5。 &安培;尝试了-1事件。 没有运气。任何想法将不胜感激。 function onPlayerStateChange(event){if(event.data == -1){//其余代码}} 提前致谢。
编辑3 /此问题的解决方案:因为您将onError设置为该函数中的函数 捕获事件并检查错误是此问题的解决方案。 function onPlayerError(event){if(event.data === 150 || event.data === 101){// rest here}}
编辑:添加更多代码。 编辑2:错误代码匹配是答案现在唯一的问题是我不知道 知道如何捕获任何想法的错误代码?
<iframe id="player" type="text/html" width="560" height="50" src="'.$striphttp.'"></iframe>
var tag = document.createElement('script');
tag.src = "http://www.youtube.com/player_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player;
function onYouTubePlayerAPIReady() {
player = new YT.Player('player', {
playerVars: { 'autoplay': 1, 'controls': 1,'autohide':1,'wmode':'opaque' },
//videoId: 'JW5meKfy3fY',
events: {
'onReady': onPlayerReady,
'onStateChange': onPlayerStateChange,
'onError': onPlayerError
}
});
}
function onPlayerError(event) {
window.location.href = "#";
}
function onPlayerReady(event) {
//event.target.mute();
}
function onPlayerStateChange(event) {
if(event.data == 0) {
window.location.href = "#";
//location.reload();
}
}
答案 0 :(得分:1)
您可以在尝试嵌入之前加载有关视频的json数据并检查限制:
var xmlhttp = new XMLHttpRequest();
var url = 'http://gdata.youtube.com/feeds/api/videos?v=2&alt=jsonc&q=TJC-subagTg';
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var response = JSON.parse(xmlhttp.responseText);
console.log(response.data.items[0].accessControl);
console.log(response.data.items[0].restrictions);
}
}
xmlhttp.open("GET", url, true);
xmlhttp.send();