本文实例讲述了jQuery中$原理。分享给大家供大家参考,具体如下:
1、外层沙箱及命名空间$
为了避免声明了一些全局变量而污染,把代码放在一个“沙箱执行”,jQuery具体的实现,都被包含在了一个立即执行函数构造的闭包里面,然后在暴露出命名空间(可以为API,函数,对象),如只暴露 $ 和 jQuery 这2个变量给外界:
rush:js;">
(function(window,undefined) {
// 用
一个函数域包起来,就是所谓的沙箱
//
在这里边var定义的变量,属于这个
函数域内的局部变量,避免污染全局
// 把当前沙箱需要的外部变量通过
函数参数引入进来
// 只要保证参数对内提供的接口的一致性,还可以随意替换传进来的这个参数
"use strict";
window.jQuery = window.$ = jQuery;
... // jQuery
代码
}) (window);
jQuery有一个针对压缩优化细节,在代码压缩时,window和undefined都可以压缩为1个字母且确保它们就是window和undefined。外层函数只传了一个参数,因此沙箱执行时,u自然会undefined,把9个字母缩成1个字母,可以看出压缩后的代码减少一些字节数。
window,u -> undefined
(function(w,u) {
"use strict";
w.jQuery = w.$ = jQuery;
var a;
if (a == u)
return;
})(window);
2、jQuery 无 new 构造
实例化一个jQuery对象的方法:
rush:js;">
$('#text').text('myJQuery'); // 无 new 构造
等价于:
rush:js;">
var text = new $('#text');
text.text('myJQuery');
使用jQuery时一般都使用无new的构造方式,直接$('')
进行构造,这也是jQuery十分便捷的一个地方。当使用无new
构造方式时,其本质是相当于new jQuery()
,在jQuery内部的实现方式是:
rush:js;">
(function(window,undefined) {
// ...
jQuery = function(selector,context) {
// 实例化
方法jQuery()实际上是
调用了其拓展的原型
方法 jQuery.fn.init
return new jQuery.fn.init(selector,context,rootjQuery);
},// jQuery.prototype是jQuery的原型,挂载在上面的
方法,即可让所有
生成的jQuery对象使用
jQuery.fn = jQuery.prototype = {
// 实例化
方法,这个
方法可以称作 jQuery 对象构造器
init: function(selector,rootjQuery) {
// ...
}
}
// jQuery 没有使用 new 运算符将 jQuery 实例化,而是直接
调用其
函数
// 要实现这样,那么 jQuery 就要看成
一个类,且返回
一个正确的实例,且实例还要能正确访问 jQuery 类原型上的
属性与
方法
// jQuery 的方式是通过原型传递
解决问题,把 jQuery 的原型传递给jQuery.prototype.init.prototype,所以通过这个
方法生成的实例 this 所指向的仍然是 jQuery.fn,所以能正确访问 jQuery 类原型上的
属性与
方法
jQuery.fn.init.prototype = jQuery.fn;
})(window);
1) 使用$('xxx')
这种实例化方式,其内部调用的是 return new jQuery.fn.init(selector,rootjQuery)
这一句话,也就是构造实例是交给了 jQuery.fn.init()
方法去完成。
2) 将 jQuery.fn.init
的 属性设置为 jQuery.fn
,那么使用 new jQuery.fn.init()
生成的对象的原型对象就是 jQuery.fn
,所以挂载到 jQuery.fn
上面的函数就相当于挂载到 jQuery.fn.init()
生成的 jQuery 对象上,所有使用 new jQuery.fn.init()
生成的对象也能够访问到 jQuery.fn 上的所有原型方法。
3) 实例化方法存在这么一个关系链 :
① jQuery.fn.init.prototype = jQuery.fn = jQuery.prototype ;
② new jQuery.fn.init()
相当于 new jQuery() ;
③ jQuery() 返回的是 new jQuery.fn.init()
,而 var obj = new jQuery()
,所以这 2 者是相当的,所以我们可以无 new 实例化 jQuery 对象。
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》及《用法总结》
希望本文所述对大家jQuery程序设计有所帮助。