覆盖默认的jQuery选择器上下文
我试图在Firefox扩展中使用jQuery,并且实际上想要使用jQuery来操作当前页面的DOM,而不是XUL文件的上下文。 因此,我在我的XUL文件中加载jQuery,并将其传递给沙盒中的一些脚本(使用Greasemonkey扩展编译器http://arantius.com/misc/greasemonkey/script-compiler )。 由于jQuery没有加载页面DOM,我想将其选择器上下文设置为页面DOM,而不是总是将其传递给jQuery调用。
我按照如何在Firefox扩展中使用jQuery的解决方案,它几乎实现了我想要的。
jQuery.noConflict(); $ = function(selector,context){ return new jQuery.fn.init(selector,context||example.doc); }; $.fn = $.prototype = jQuery.fn;
我可以调用jQuery()函数,页面DOM将用作上下文。 但是,我不能使用像jQuery.trim这样的函数,因为它们没有定义。
我认为这条线来自解决方案
$.fn = $.prototype = jQuery.fn;
将让我自己的jQuery对象inheritance所有jQuery原型属性,但显然不会。
给一个vanilla jQuery对象,如何重新定义它以使用某个元素作为选择器上下文,同时保留所有jQuery函数?
.trim(),. ajax()等是静态方法,这意味着它们绑定到jQuery构造函数而不是它的原型。
jQuery.noConflict(); $ = function(selector,context){ return new jQuery.fn.init(selector,context||example.doc); }; $.fn = $.prototype = jQuery.fn; jQuery.extend($, jQuery); // copy's trim, extend etc to $
然而,一个可能很好的方法是保持jQuery完整并执行以下操作:
var fromDoc = $(document); // and if you want to find stuff: fromDoc.find('div').doSomething(); fromDoc.find('.someClass').doSomethingElse();
这也是一种优化,因为不必为每个查询手动设置上下文。
var jQueryInit = $.fn.init; $.fn.init = function(arg1, arg2, rootjQuery){ arg2 = arg2 || window.document; return new jQueryInit(arg1, arg2, rootjQuery); };
另一种方法是覆盖构造函数:
var initjQuery = jQuery.fn.init; $.fn.init = function(s,c,r) { c = c || window.document; return new initjQuery(s,c,r); };