-1

ユーザースクリプトを1つのドメインに制限していますが、Jqueryを使用するサイトにアクセスすると、スクリプトがアクティブなときにあらゆる種類の厄介な問題が発生します。Chromeでエラーコンソールを確認すると、すべてのサイトで同じエラーが表示されます。

"Uncaught TypeError:Property'$' of object [object Window]"

これは何が原因ですか?私の目的は、jqueryとプロトタイプの両方を使用するサイトでユーザースクリプトを競合なしモードで実行することです。私は上記のコードを作成しなかったvar = myFunctionので、私が遭遇している問題の原因が何であるかわかりません。助言がありますか?

// ==UserScript==
// @name          Restore Dashboard Tags
// @namespace     http://userstyles.org
// @description   This script restores a user's tracked tag list to the sidebar on tumblr
// @author       
// @homepage     
// @history       1.0 first version
// @include http://www.tumblr.com/*
// @match   http://www.tumblr.com/*

// ==/UserScript==

var jQuery, $ = null;

function addJQuery(callback) {
var p = null;

if(window.opera || window.navigator.vendor.match(/Google/)) {
    var div = document.createElement("div");
    div.setAttribute("onclick", "return window;");
    p = div.onclick();
}
else {
    p = Window;
}

jQuery = $ = p.jQuery.noConflict();
callback();
}

var myFunction = function() {
jQuery('div#right_column ul:first-child').after('<ul class="controls_section" id="tracked_tags"></ul>');
jQuery('div.tracked_tags a').each(function (i) {
    var tagID = jQuery(this).attr("id");
    var tagIDNumber = tagID.replace('tag_','');
    var tagName = jQuery(this).attr("href");
    var tagNameClean = tagName.replace('/tagged/','');
    var tagContent ='';
    tagContent += '<li><a href="'+tagName+'" id="'+tagID+'" class="tag">';
    tagContent += '<div class="hide_overflow">'+tagNameClean+'</div>';
    tagContent += '<span id="tag_unread_'+tagIDNumber+'" class="count" style=""></span></a></li>';                  
    jQuery(tagContent).appendTo('div#right_column ul#tracked_tags');                                                                      
}); 
};

var NewPosts = function(){
    jQuery('div.tracked_tags > div').each(function (i) {
        var thisIndex = jQuery(this).index();
        if (jQuery(this).find('small').length){         
            var postCount = jQuery(this).find('small').text();      
            jQuery('div#right_column ul#tracked_tags li:eq('+thisIndex+')').find('.count').html(postCount.replace("new posts", "") );
        }
    });
                setTimeout(NewPosts,30000);
}


addJQuery(myFunction);
addJQuery(NewPosts);
4

1 に答える 1

0

問題は解決しました!別のサイトの誰かが犯人を次のように識別しましたjQuery = $ = p.jQuery.noConflict();。私は Jquery の独自のコピーをロードしていなかったので、noConflict は必要ありませんでした。その使用法は、ページの残りの部分から Jquery を隠していました。

于 2012-10-04T06:29:38.703 に答える