默认情况下,jQuery用$作为自身的快捷方式。
如同时导入jQuery和prototype库。
一、jQuery库在其他库之后导入
1、移交控制权
jQuery.noConflict();//将变量$的控制权让渡给prototype.js
jQuery(function(){//使用jQuery
jQuery("p").click(function(){
});
});
$("pp").style.display = 'none'; //使用prototype
2、自定义快捷方式
var $j = jQuery.noConflict();//自定义一个比较短快捷方式
$j(function(){//使用jQuery
$j("p").click(function(){
});
});
$("pp").style.display = 'none'; //使用prototype
3、移交控制权后,内部继续使用$
(a):
jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
jQuery(function($){
//使用jQuery$("p").click(function(){
//继续使用 $ 方法
});
});
$("pp").style.display = 'none'; //使用prototype
(b):最理想方式,改变最少代码实现全面的兼容性
jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
(function($){
//定义匿名函数并设置形参为$$(function(){
//匿名函数内部的$均为jQuery$("p").click(function(){
//继续使用 $ 方法alert($(this).text());
});
});
})(jQuery); //执行匿名函数且传递实参jQuery
$("pp").style.display = 'none'; //使用prototype
二、jQuery在其他库之前导入
jQuery(function(){ //直接使用 jQuery ,没有必要调用"jQuery.noConflict()"函数。
jQuery("p").click(function(){
alert( jQuery(this).text() );
});
});
$("pp").style.display = 'none'; //使用prototype