默认情况下,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