jQueyr源码分析学习笔记(四)

构造jQuery对象模块的总体源码结构如代码:

(function(window,undefined){

        //构造jQuery对象
        var jQuery =(function(){
            var jQuery = function(selector,context){
                return new jQuery.fn.init(selector,context,rootjQuery);
                    }
                    //局部变量声明
            jQuery.fn = jQuery.prototype = {
                constructor:jQuery,
                init:function(selector,context,rootjQuery){
                    //省略
                }
                //原型属性和方法省略
            };
            jQuery.fn.init.prototype = jQuery.fn;
            jQuery.extend = jQuery.fn.extend = function(){
                //省略
            };
            jQuery.extend({
                //静态属性和方法
            });
            return jQuery;
        })();
        window.jQuery =window.$= jQuery;
    })(window)

通常我们创建一个对象或实例的方式是在运算符new后紧跟一个构造函数,但是,如果构造函数有返回值,运算符new所创建的对象会被丢弃,返回值将作为new表达式的值。jquery利用了这一特性,通过在构造函数jQuery()内部运算符创建并返回另一个构造函数的实例,省去了构造函数jQuery()前面的运算符new,即我们创建jQuery对象时,可以省略运算符new直接写jQuery()。

jQuery.fn是jQuery.prototype简写,可以少写7个字符,方便拼写。

调用构造函数jQuery()返回的jQuery对象实际上是构造函数jQuery.fn.init()的实例,之所以能在构造函数jQuery.fn.init()的实例上调用构造函数jQuery()的原型方法和属性,是因为
在执行 jQuery.fn.init.prototype = jQuery.fn时,用构造函数jQuery()的原型对象覆盖了构造函数jQuery.fn.init()的原型对象,从而使构造函数jQuery.fn.init()的实例也可以访问构造函数jQuery()的原型和方法和属性。

在原型对象jQuery.prototype上定义的属性和方法会被所有的jQuery对象继承,可以有效减少每个jQuery对象所需的内存,事实上,jQuery对象只包含了5种非继承属性,其余都继承自原型对象jQuery.prototype;在构造函数jQuery.fn.init()中设置了整型属性、length、selector、context;在原型方法.pushStack()中设置了prevObject。因此,也不必因为jQuery对象带有太多的属性和方法而担心会占用太多的内存

你可能感兴趣的:(jquery,源码,对象,结构,函数,jQuery,源码研究)