|
jQuery代碼的頭部是License聲明。采用了GPLv2和MIT雙協(xié)議。而在jQuery聲明下是另一個(gè)項(xiàng)目的聲明:Sizzle。這是jQuery作者另外的一個(gè)開源項(xiàng)目,在MIT、BSD和GPL下發(fā)布。它是一個(gè)獨(dú)立的selector實(shí)現(xiàn)(pure-JavaScript CSS selector engine),可以獨(dú)立使用。它的壓縮版本只有3KB多一點(diǎn),號(hào)稱效率最高的選擇器實(shí)現(xiàn)。jQuery從1.3開始使用Sizzle代替了原來的selector實(shí)現(xiàn)。
JS代碼中有大量的()和{},這里使用的是Vim閱讀,因?yàn)?命令可以快速的找到匹配的括號(hào)。
代碼總體結(jié)構(gòu)和變量
jQuery的代碼整體上就是一個(gè)匿名函數(shù)調(diào)用:
復(fù)制代碼 代碼如下:
(function (window, undefined) {
// ...
})(window);
這是為了避免污染全局對(duì)象,同時(shí)也可以方便的管理執(zhí)行上下文。這個(gè)技巧在JS代碼中經(jīng)常見到,在jQuery代碼中也很常見。比如,在jQuery和其他JS庫同時(shí)使用時(shí),$符號(hào)可能已經(jīng)被使用了。為了仍然使用$符號(hào):
復(fù)制代碼 代碼如下:
(function ($) {
// $("...")... 照常使用$
})(jQuery);
在這里傳入真正的jQuery對(duì)象。
下面進(jìn)入真正的實(shí)現(xiàn)部分,首先是$,也就是jQuery對(duì)象的聲明,其中最基本的兩個(gè)成員也列出來了:
復(fù)制代碼 代碼如下:
var jQuery = (function() {
var jQuery = function(selector, context) {
// 真正的初始化函數(shù)
return new jQuery.fn.init(selector, context, rootjQuery);
},
// 一大堆變量聲明
// fn是主要的函數(shù)實(shí)現(xiàn)點(diǎn),也是jQuery插件的起點(diǎn)。實(shí)際上就是JS原型
jQuery.fn = jQuery.prototype = {
};
// 一個(gè)擴(kuò)展對(duì)象用的函數(shù),可以動(dòng)態(tài)地往對(duì)象上加成員。以后往jQuery里面加成員都是用extend函數(shù)完成的。
jQuery.extend = jQuery.fn.extend = function() {
};
// ...
return jQuery;
})();
jQuery對(duì)象是核心對(duì)象,所有$(...)得到的都是jQuery對(duì)象,除了少部分直接實(shí)現(xiàn)在jQuery下的Utility函數(shù)之外,大部分函數(shù)都是用extend方法加到j(luò)Query對(duì)象里的。
php技術(shù):jQuery 源碼分析筆記,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。