jquery的总体架构分析及实现示例详解
jQuery整体框架甚是复杂,也不易读懂,这几日一直在研究这个笨重而强大的框架。jQuery的总体架构可以分为:入口模块、底层模块和功能模块。这里,我们以jquery-1.7.1为例进行分析。
jquery的总体架构
16(function(window,undefined){
//构造jQuery对象
22 varjQuery=(function(){
25 varjQuery=function(selector,context){
27 returnnewjQuery.fn.init(selector,context,rootjQuery);
28 },
//一堆局部变量声明
97 jQuery.fn=jQuery.prototype={
98 constructor:jQuery,
99 init:function(selector,context,rootjQuery){...},
//一堆原型属性和方法
319 };
322 jQuery.fn.init.prototype=jQuery.fn;
324 jQuery.extend=jQuery.fn.extend=function(){...};
388 jQuery.extend({
//一堆静态属性和方法
892 });
955 returnjQuery;
957 })();
//省略其他模块的代码...
9246 window.jQuery=window.$=jQuery;
9266})(window);
分析一下以上代码,我们发现jquery采取了匿名函数自执行的写法,这样做的好处就是可以有效的防止命名空间与变量污染的问题。缩写一下以上代码就是:
(function(window,undefined){
varjQuery=function(){}
//...
window.jQuery=window.$=jQuery;
})(window);
参数window
匿名函数传了两个参数进来,一个是window,一个是undefined。我们知道,在js中变量是有作用域链的,这两个变量的传入就会变成匿名函数的局部变量,访问起来的时候速度会更快。通过传入window对象可以使window对象作为局部变量使用,那么,函数的参数也都变成了局部变量,当在jquery中访问window对象时,就不需要将作用域链退回到顶层作用域,从而可以更快的访问window对象。
参数undefined
js在查找变量的时候,js引擎首先会在函数自身的作用域中查找这个变量,如果没有的话就继续往上找,找到了就返回该变量,找不到就返回undefined。undefined是window对象的一个属性,通过传入undefined参数,但又不进行赋值,可以缩短查找undefined时的作用域链。在自调用匿名函数的作用域内,确保undefined是真的未定义。因为undefined能够被重写,赋予新的值。
jquery.fn是啥?
jQuery.fn=jQuery.prototype={
constructor:jQuery,
init:function(selector,context,rootjQuery){...},
//一堆原型属性和方法
};
通过分析以上代码,我们发现jQuery.fn即是jQuery.prototype,这样写的好处就是更加简短吧。之后,我们又看到jquery为了简洁,干脆使用一个$符号来代替jquery使用,因此,在我们使用jquery框架的使用经常都会用到$(),
构造函数jQuery()
图片描述
jQuery的对象并不是通过newjQuery创建的,而是通过newjQuery.fn.init创建的:
varjQuery=function(selector,context){
returnnewjQuery.fn.init(selector,context,rootjQuery);
}