二、jQuery和其他库冲突
更新:HHH   时间:2023-1-7


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


返回web开发教程...