二、jQuery和其他库冲突
默认情况下,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
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。