谈谈 jQuery 中的防冲突(noConflict)机制
许多的 JS 框架类库都选择使用 $ 符号作为函数或变量名,jQuery 是其中最为典型的一个。在 jQuery 中,$ 符号只是 window.jQuery 对象的一个引用,因此即使 $ 被删除,window.jQuery 依然是保证整个类库完整性的坚强后盾。jQuery 的 API 设计充分考虑了多框架之间的引用冲突,我们可以使用 jQuery.noConflict 方法来轻松实现控制权的移交。
jQuery.noConflict 方法包含一个可选的布尔参数[1],用以决定移交 $ 引用的同时是否移交 jQuery 对象本身:
jQuery.noConflict([removeAll])
缺省情况下,执行 noConflict 会将变量 $ 的控制权移交给第一个产生 $ 的库;当 removeAll 设置为 true 时,执行 noConflict 则会将 $ 和 jQuery 对象本身的控制权全部移交给第一个产生他们的库。
例如在 KISSY 和 jQuery 混用,并且惯用 $ = KISSY 来简化 API 操作的时候,就能够通过这个方法解决命名冲突的问题。
那么这个机制是如何实现的呢?阅读 jQuery 源码开头[2],首先做的一件事情是这样的:
// Map over jQuery in case of overwrite _jQuery = window.jQuery, // Map over the $ in case of overwrite _$ = window.$,
容易理解的是,jQuery 通过两个私有变量映射了 window 环境下的 jQuery 和 $ 两个对象,以防止变量被强行覆盖。一旦 noConflict 方法被调用,则通过 _jQuery, _$, jQuery, $ 四者之间的差异,来决定控制权的移交方式,具体的代码如下:
noConflict: function( deep ) { if ( window.$ === jQuery ) { window.$ = _$; } if ( deep && window.jQuery === jQuery ) { window.jQuery = _jQuery; } return jQuery; }
再来看上面所说的参数设定问题,如果 deep 没有设置,_$ 覆盖 window.$,此时 jQuery 别名 $ 失效,但 jQuery 本身完好无损。如果有其他类库或代码重新定义了 $ 变量,它的控制权就完全交接出去了。反之如果 deep 设置为 true 的话,_jQuery 覆盖 window.jQuery,此时 $ 和 jQuery 都将失效。
这种操作的好处是,不管是框架混用还是 jQuery 多版本共存这种高度冲突的执行环境,由于 noConflict 方法提供的移交机制,以及本身返回未被覆盖的 jQuery 对象,完全能够通过变量映射的方式解决冲突。
但无法避免的事实是可能导致的插件失效等问题,当然通过简单修改上下文参数即可恢复 $ 别名:
var query = jQuery.noConflict(true); (function ($) { // 插件或其他形式的代码,也可以将参数设为 jQuery })(query);
[1] http://api.jquery.com/jQuery.noConflict/#jQuery-noConflict-removeAll
[2] https://github.com/jquery/jquery/blob/master/src/core.js
建议继续学习:
- JQuery实现Excel表格呈现 (阅读:46541)
- 分享一个JQUERY颜色选择插件 (阅读:12751)
- jQuery插件---轻量级的弹出窗口wBox. (阅读:9710)
- 10个强大的Ajax jQuery文件上传程序 (阅读:7784)
- jQuery的data()方法 (阅读:7661)
- jQuery性能优化指南 (阅读:7410)
- jQuery Color Animations颜色动画插件 (阅读:7179)
- 精于图片处理的10款jQuery插件 (阅读:6315)
- jQuery中getJSON跨域原理详解 (阅读:5644)
- 配合jquery实现异步加载页面元素 (阅读:5398)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:邦彦 来源: TaoBaoUED
- 标签: jQuery noConflict 冲突
- 发布时间:2013-06-21 00:05:59
- [4615] 最常见的电话号码
- [366] QR码分析
- [199] SmartSprites - 命令行形式的C
- [60] 如何拿下简短的域名
- [56] Oracle MTS模式下 进程地址与会话信
- [54] Twitter/微博客的学习摘要
- [53] Go Reflect 性能
- [53] android 开发入门
- [53] 图书馆的世界纪录
- [52] IOS安全–浅谈关于IOS加固的几种方法