关于jQuery库冲突的完美解决办法
前⾔
⼀次⾯试中⾯试官问到jQuery和别的库冲突怎么解决?虽然以前看过,但是我已经不记得了。
我的思路就是如果让我来设计,那我就⽤⼀个默认值$,不传参数,那就⽤$,最后就挂载在window.$上,传参数就⽤传⼊名字,⽐如传⼊jq,那我就挂载在window.jq上。
var myControl="jq";
(function(name){
var $=name ||"$"; //name存在$的值就是name的值,不存在或为null,$的值为字符串"$"
console.log($);
window[$]=function(){
alert("123");
}
})(myControl)
window[myControl]();
事实上这肯定不是jquery解决冲突的办法了。那就看看jQuery怎么解决冲突吧。
jQuery多个版本或和其他js库冲突主要是常⽤的$符号的冲突。
⼀、冲突的解决
1、同⼀页⾯jQuery多个版本冲突解决⽅法
<body>
<!-- 引⼊1.6.4版的jq -->
<script src="leapis/ajax/libs/jquery/1.6.4/jquery.js"></script>
<script> var jq164 = Conflict(true); </script>
<!-- 引⼊1.4.2版的jq -->
<script src="leapis/ajax/libs/jquery/1.4.2/jquery.js"></script>
<script> var jq142 = Conflict(true); </script>
<script>
(function($){
//此时的$是jQuery-1.6.4
$('#');
})(jq164);
</script>
<script>
jq142(function($){
//此时的$是jQuery-1.4.2
$('#');
});
</script>
</body>
2、jQuery库在其他库之后导⼊
jQuery noConflict() ⽅法会释放会 $ 标识符的控制,这样其他脚本就可以使⽤它了。
1、可以通过jQuery全名替代简写的⽅式来使⽤ jQuery
在其他库和jQuery库都加载完毕后,可以在任何时候调⽤Conflict()函数来将变量$的控制权移交给其他JavaSript库。然后就可以在程序⾥将jQuery()函数作为jQuery对象的制造⼯⼚。
<script src="prototype.js" type="text/javascript"></script>
<script src="jquery.js" type="text/javascript"></script>
<p id="pp">test---prototype</p>
<p>test---jQuery</p>
<script type="text/javascript">
jQuery(function(){  //使⽤jQuery
jQuery("p").click(function(){
alert( jQuery(this).text() );
});
});
//此处不可以再写成$,此时的$代表prototype.js中定义的$符号。
$("pp").style.display = 'none'; //使⽤prototype
</script>
2、⾃定义⼀个快捷⽅式
noConflict()可返回对 jQuery 的引⽤,可以把它存⼊⾃定义名称,例如jq,$J变量,以供稍后使⽤。
这样可以确保jQuery不会与其他库冲突,同时⼜使⽤⾃定义⼀个快捷⽅式。
<script type="text/javascript">
var $j = Conflict(); //⾃定义⼀个⽐较短快捷⽅式
$j(function(){  //使⽤jQuery
$j("p").click(function(){
alert( $j(this).text() );
});
});
$("pp").style.display = 'none'; //使⽤prototype
</script>
3、在不冲突的情况下仍然⽤$
如果想在jQuery 代码块使⽤ $ 简写,不愿意改变这个快捷⽅式,可以把 $ 符号作为变量传递给 ready ⽅法。这样就可以在函数内使⽤ $ 符号了,⽽在函数外,依旧不得不使⽤ "jQuery"。
<script type="text/javascript">
jQuery(document).ready(function($){
$("p").click(function(){ //继续使⽤ $ ⽅法
alert( $(this).text() );
jquery在线库});
});
//或者如下
jQuery(function($){  //使⽤jQuery
$("p").click(function(){ //继续使⽤ $ ⽅法
alert( $(this).text() );
});
});
</script>
或者使⽤IEF语句块,这应该是最理想的⽅式,因为可以通过改变最少的代码来实现全⾯的兼容性。
在我们⾃⼰写jquery插件时,应该都使⽤这种写法,因为我们不知道具体⼯作过程中是如何顺序引⼊各种js库的,⽽这种语句块的写法却能屏蔽冲突。
<script type="text/javascript">
(function($){  //定义匿名函数并设置形参为$
$(function(){  //匿名函数内部的$均为jQuery
$("p").click(function(){ //继续使⽤ $ ⽅法
alert($(this).text());
});
});
})(jQuery);    //执⾏匿名函数且传递实参jQuery
$("pp").style.display = 'none'; //使⽤prototype
</script>
3、jQuery库在其他库之前导⼊
jQuery库在其他库之前导⼊,$的归属权默认归后⾯的JavaScript库所有。那么可以直接使⽤"jQuery"来做⼀些jQuery的⼯作。同时,可以使⽤$()⽅法作为其他库的快捷⽅式。这⾥⽆须调⽤Conflict()函数。
<!-- 引⼊ jQuery -->
<script src="../../scripts/jquery.js" type="text/javascript"></script>
<!-- 引⼊ prototype -->
<script src="lib/prototype.js" type="text/javascript"></script>
<body>
<p id="pp">Test-prototype(将被隐藏)</p>
<p >Test-jQuery(将被绑定单击事件)</p>
<script type="text/javascript">
jQuery(function(){ //直接使⽤ jQuery ,没有必要调⽤"Conflict()"函数。
jQuery("p").click(function(){
alert( jQuery(this).text() );
});
});
$("pp").style.display = 'none'; //使⽤prototype
</script>
</body>
⼆、原理
1、源码
源码:看⼀下源码⾥怎么做到的
var
// Map over jQuery in case of overwrite
_jQuery = window.jQuery,
/
/ Map over the $ in case of overwrite
_$ = window.$,
noConflict: function( deep ) {
if ( window.$ === jQuery ) {
window.$ = _$;
}
if ( deep && window.jQuery === jQuery ) {
window.jQuery = _jQuery;
}
return jQuery;
}
});
在jQuery加载的时候,通过事先声明的_jQuery变量获取到当前window.jQuery,通过_$获取到当前window.$。通过d()把noConflict挂载到jQuery下⾯。所以我们在调⽤的时候都是Conflict()这样调。
在调⽤noConflict()时做了2个判断,
第⼀个if,把$的控制权交出去。
第⼆个if,在noConflict()传参的时候把,jQuery的控制权交出去。
最后noConflict()返回jQuery对象,⽤哪个参数接收,哪个参数将拥有jQuery的控制权。
2、验证
//冲突
var $ = 123; //假设其他库中$为123
$(
function () {
console.log($); //报错Uncaught TypeError: $ is not a function
}
);
解决冲突
//解决冲突
var jq = $.noConflict();
var $ = 123;
jq(function () {
alert($); //123
});
释放$控制权例⼦
<script>
var $ = 123; // window.$是123,存储在私有的_$上。
</script>
<script src="code.jquery/jquery-2.2.4.js"></script>
<body>
<div>aaa</div>
<script>
var jq = $.noConflict();//当window.$===jQuery的时候,把_$赋给了window.$。
jq(function () {
alert($); //123
});
</script>
释放jQuery控制权例⼦
参数deep的作⽤:deep⽤来放弃jQuery对外的接⼝。
如下,noConflict()不写参数,弹出jQuery为构造函数。
<script>
var $ = 123;
var jQuery=456;
</script>
<script src="code.jquery/jquery-2.0.3.js"></script>
<body>
<div>aaa</div>
<script>
var jq = $.noConflict();
jq(function () {
alert(jQuery); //构造函数
});
</script>
如果写个参数true,会弹出456。
<script>
var $ = 123;
var jQuery=456;
</script>
<script src="code.jquery/jquery-2.0.3.js"></script>
<body>
<div>aaa</div>
<script>
var jq = $.noConflict(true); //写了true或者参数的时候,deep为真window.jQuery===jQuery为真,所以进⼊if条件。把456赋值给window.jQuery
jq(function () {
alert(jQuery); //456
});
</script>
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作能带来⼀定的帮助,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。