2016-10-01 113 views
0

好吧,我是一名贸易SQL程序员,但我试图找出一个(据说)简单的greasemonkey javascript,从其他很多在这里找到的例子拼凑在一起。Javascript on YouTube Video Change

基本上,我想检查当前的视频用户对阵“好”用户。如果他们在列表中找到,没问题;如果它们不是,则将该页面重定向回youtube.com。我有脚本处理第一个视频播放,但是当通过链接选择另一个视频时,文档对象似乎并未加载,或者getElementByClassName未找到任何内容并返回“未定义”。

这是迄今充分的GreaseMonkey脚本:

// ==UserScript== 
// @name  YouTube Limit To Users 
// @namespace http://userscripts.org/users/23652 
// @include  https://www.youtube.com/watch 
// @version  1 
// @grant  GM_getValue 
// @grant  GM_setValue 
// ==/UserScript== 

var goodYoutubers=["Sqaishey Quack", "Graser10", "Good Mythical Morning"]; 

window.onload = DoCheckForUser(); 

function youtubePageChange() 
{ 
    DoCheckForUser(); 
    $('body').on('transitionend', function(event) 
    { 
    if (event.target.id != 'progress') return false; 
    DoCheckForUser(); 
    }); 
} 

$(youtubePageChange); 

function DoCheckForUser() { 
    var y = document.getElementsByClassName('yt-user-info'); 
    var aNode = y[0]; //<<< this goes "undefined" 
    var currentUser = aNode.textContent.trim(); 
    alert(currentUser); 

    var indexUser = goodYoutubers.indexOf(currentUser); 
    if (indexUser < 0) 
    { 
     alert(currentUser + " is NOT an approved YouTuber!"); 
     window.location = "http://www.youtube.com"; 
    } 
    else 
    { 
     alert(currentUser + " is an approved YouTuber!"); 
    } 
} 

回答

0

在后台脚本:

window.addEventListener("spfdone", process); // old youtube design 
window.addEventListener("yt-navigate-start", process); // new youtube design 
document.addEventListener("DOMContentLoaded", process); // one-time early processing 
window.addEventListener("load", process); // one-time late postprocessing