Javascript web扩展中的Youtube播放器iframe API
我正在制作一个youtubeJavascript web扩展中的Youtube播放器iframe API,javascript,iframe,youtube-api,firefox-addon-webextensions,Javascript,Iframe,Youtube Api,Firefox Addon Webextensions,我正在制作一个youtube网络扩展。如何从youtube视频页面(www.youtube.com/watch?v=videoId)上的内容脚本中获取对YT.Player的引用 在我的主内容脚本中有这个(来自),但函数onYouTubeIframeAPIReady从不触发: var tag = document.createElement('script'); tag.src = "https://www.youtube.com/iframe_api"; var firstScriptTag
网络扩展。如何从youtube视频页面(www.youtube.com/watch?v=videoId)上的内容脚本中获取对YT.Player
的引用
在我的主内容脚本中
有这个(来自),但函数onYouTubeIframeAPIReady
从不触发:
var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player;
function onYouTubeIframeAPIReady() {
console.log("onYouTubeIframeAPIReady");
////normally I would create the player like below, but I need the existing one
//player = new YT.Player('player', {
// modestbranding: 1,
// cc_load_policy: 1,
// wmode: "opaque",
// height: '390',
// width: '640',
// videoId: videoId,
// enablejsapi: 1,
// events: {
// 'onReady': onPlayerReady,
// 'onStateChange': onPlayerStateChange,
// 'onApiChange': onApiChange
// }
//});
}
有趣的是,我可以从浏览器控制台获得播放器
:
var player = $("#movie_player");
但是这个调用在内容脚本中不起作用(我得到了一个不同类型的对象)。相关:@Shog9是的,我已经看到了,并尝试将函数放在后台脚本中(我还在学习和实验)但是没有用..我怀疑这里的核心问题是您正在沙箱中运行-因此您的脚本对页面上运行的脚本不可见,反之亦然。尝试将您的逻辑直接注入页面。