jQuery源码分析5
2015-12-29 13:56
567 查看
jQuery多库共存处理
多库共存换句话说可以叫无冲突处理。核心为接管权利的交接,谁当家。就是意思当人多的时候你喊TOM,可能会有好多人回头,为了防止更新或者使用中的冲突,要把使用权空出来。
特别要库在编码是注意引入的顺序!!
总的来说会有2种情况会遇到:
1、$太火热,jQuery采用$作为命名空间,不免会与别的库框架或者插件相冲突。
2、jQuery版本更新太快,插件跟不上,导致不同版本对插件的支持度不一样。
出于以上的原因,jQuery给出了解决方案–– noConflict函数。
引入jQuery运行这个noConflict函数将变量$的控制权让给第一个实现它的那个库,确保jQuery不会与其他库的$对象发生冲突。
在运行这个函数后,就只能使用jQuery变量访问jQuery对象。例如,在要用到$("aaron")的地方,就必须换成jQuery("aaron"),因为$的控制权已经让出去了。
使用DEMO:
jQuery.noConflict(); // 使用 jQuery jQuery("aaron").show(); // 使用其他库的 $() $("aaron").style.display = ‘block’;
这个函数必须在你导入jQuery文件之后,并且在导入另一个导致冲突的库之前使用。当然也应当在其他冲突的库被使用之前,除非jQuery是最后一个导入的。
由于比较简单,我们直接上代码解说:
Var _jQuery = window.jQuery, _$ = window.$; jQuery.noConflict = function( deep ) { if ( window.$ === jQuery ) { window.$ = _$; } if ( deep && window.jQuery === jQuery ) { window.jQuery = _jQuery; } return jQuery; };
如果我们需要同时使用jQuery和其他JavaScript库,我们可以使用 $.noConflict()把$的控制权交给其他库。旧引用的$ 被保存在jQuery的初始化; noConflict() 简单的恢复它们。
通过类似swap交换的概念,先把之前的存在的命名空间给缓存起来,通过对比当前的命名空间达到交换的目的,首先,我们先判断下当前的的$空间是不是被jQuery接管了,如果是则让出控制权给之前的_$引用的库,如果传入deep为true的话等于是把jQuery的控制权也让出去了。
如果不通过noConflict处理的话其后果可想而知,香喷喷的$大家都“觊觎已久”。冲突不可避免。
实例:
<div id="aaron">测试noConflict效果</div> <script type="text/javascript"> $("#aaron").click(function() { $.noConflict(); //让出控制权 if (!$) { show("使用noConflict后,$不存在") } if (jQuery) { show("使用noConflict后,jQuery存在") } //通过闭包隔离出$ ;(function($) { if ($) { show("通过闭包隔离后,转为局部变量$存在") } })(jQuery); }) function show(data) { jQuery("body").append('<li>' + data + '</li>') } </script>
结果:
测试noConflict效果
使用noConflict后,jQuery存在
通过闭包隔离后,转为局部变量$存在
1.在导入jquery.js的时候,将prototype.js中的$进行保存,var _$ = window.$;
2.jquery完全导入之后,此时的window.$已经被替换为jquery中的$
3.当执行noConflict函数,此时的window.$ === jQuery 成立,进而window.$被替换成之前保存的_$,即为prototype中的$
4.此时即完成了jQuery让出$控制权的功能
相关文章推荐
- jQuery源码分析4
- 解决ecshop模板兼容jquery问题
- jQuery
- jQuery中bind,live,delegate,on的区别
- Jquery-获取兄弟元素
- js与jQuery操作select大全
- jquery提交ajax Form(未完成)
- jQuery中attr()与prop()函数用法实例详解(附用法区别)
- 关于火狐中使用jquery的animate做动画效果的问题解决
- jQuery带tab切换搜索框样式代码
- jquery hide和show使用
- jquery移出select指定option
- jquery一次赋值多个元素
- jquery跳出each循环
- jquery 表格行计算
- jquery源码学习3
- jquery layout学习
- jquery源码分析2
- jQuery、ajaxFileUpload上传图片记录
- Jquery使用小技巧汇总