jQuery的框架介紹
jQuery使用有一段時(shí)間了,但是有一些API的實(shí)現(xiàn)實(shí)在想不通。小編參考相關(guān)資料源碼,現(xiàn)在把我的學(xué)習(xí)過程和收獲分享給大家。
下面將使用簡(jiǎn)化的代碼來介紹,主要關(guān)注jQuery的實(shí)現(xiàn)思想~>_<~
//匿名立即執(zhí)行函數(shù) //.防止污染全局空間 //.選擇性保護(hù)內(nèi)部變量 (function(window, undefined){ //第二參數(shù)undefined設(shè)置而不傳的原因: // 外部發(fā)生這種情況:var undefined = 時(shí),undefined會(huì)被篡改 // 設(shè)置第二參數(shù)而不傳,則undefined就會(huì)被重置回原來值 function jQuery(sel){ return new jQuery.prototype.init(sel); } jQuery.prototype = { constructor: jQuery, init: function(sel){ if(typeof sel === 'string'){ var that = this; //jQuery內(nèi)部使用的是Sizzle,這里使用querySelectorAll替代 var nodeList = document.querySelectorAll(sel); Array.prototype.forEach.call(nodeList, function(val, i){ that[i] = val; }) this.selector = sel; this.length = nodeList.length; } } } jQuery.prototype.init.prototype = jQuery.prototype; //對(duì)外暴露jQuery:將jQuery綁定在window上面 window.$ = jQuery; })(window);
--------------------------
jQuery一開始使用匿名立即執(zhí)行函數(shù)包裹其內(nèi)部,并在第5行對(duì)外暴露;
所謂的匿名立即執(zhí)行函數(shù)即這個(gè)函數(shù)是匿名的(沒有名字)、定義完后立即調(diào)用的;
當(dāng)我們?cè)谕獠空{(diào)用$("div")時(shí),其實(shí)調(diào)用的就是內(nèi)部的jQuery("div");
(function(window, undefined){ //內(nèi)部變量 //對(duì)外暴露jQuery:將jQuery綁定在window上面 window.$ = jQuery; })(window); $("div")
--------------------------
好,接下來稍復(fù)雜點(diǎn),下面的代碼主要實(shí)現(xiàn)如圖的互相引用:
以$('div')調(diào)用為例:
從第2行代碼可以看出,jQuery使用jQuery.prototype.init來實(shí)例化jQuery對(duì)象,但這會(huì)帶來一個(gè)問題:
實(shí)例化的對(duì)象只能訪問到init下的變量,而不能訪問到j(luò)Query.prototype(jQuery對(duì)外提供的API綁定在該對(duì)象下)。
于是乎,補(bǔ)寫第21行代碼,將init.prototype指向jQuery.prototype即可。
這樣就完成了,使用init來實(shí)例化,且可以在init作用域下訪問到j(luò)Query.prototype。
function jQuery(sel){ return new jQuery.prototype.init(sel); } jQuery.prototype = { constructor: jQuery, init: function(sel){ if(typeof sel === 'string'){ var that = this; //jQuery內(nèi)部使用的是Sizzle,這里使用querySelectorAll替代 var nodeList = document.querySelectorAll(sel); Array.prototype.forEach.call(nodeList, function(val, i){ that[i] = val; }) this.selector = sel; this.length = nodeList.length; } } } jQuery.prototype.init.prototype = jQuery.prototype;
為什么使用jQuery.prototype.init來實(shí)例化對(duì)象,而不直接使用jQuery函數(shù)呢?
假設(shè)使用jQuery函數(shù)來實(shí)例化對(duì)象,這樣對(duì)象之間的引用的確可以簡(jiǎn)化為 jQuery-->jQuery.prototype。
但是調(diào)用會(huì)變得繁瑣起來:new $('div'),所以基于這個(gè)考慮(猜測(cè)(⊙0⊙)),在內(nèi)部使用較為復(fù)雜的實(shí)現(xiàn),來簡(jiǎn)化調(diào)用。
--------------------------
好,最后,再來看一下init的實(shí)現(xiàn)。同樣也簡(jiǎn)化了代碼,只實(shí)現(xiàn)了最常用的一種情況。
jQuery會(huì)把獲取到的nodeList處理成數(shù)組(方便后續(xù)使用),并在其下掛載一些變量,如length,selector。
init: function(sel){ if(typeof sel === 'string'){ var that = this; //jQuery內(nèi)部使用的是Sizzle,這里使用querySelectorAll替代 var nodeList = document.querySelectorAll(sel); Array.prototype.forEach.call(nodeList, function(val, i){ that[i] = val; }) this.selector = sel; this.length = nodeList.length; } }
本文所述到此結(jié)束,下篇文章將給大家介紹jQuery鏈?zhǔn)秸{(diào)用與show知識(shí)淺析,欲了解更多資訊敬請(qǐng)關(guān)注腳本之家網(wǎng)站!
相關(guān)文章
jQuery實(shí)現(xiàn)的Div窗口震動(dòng)特效
這篇文章主要介紹了jQuery實(shí)現(xiàn)的Div窗口震動(dòng)特效 ,需要的朋友可以參考下2014-06-06JQuery中Ajax()的data參數(shù)類型實(shí)例分析
這篇文章主要介紹了JQuery中Ajax()的data參數(shù)類型,結(jié)合實(shí)例形式較為詳細(xì)的分析了ajax方法中data的具體類型,需要的朋友可以參考下2015-12-12jQuery向webApi提交post json數(shù)據(jù)
這篇文章主要介紹了jQuery向webApi提交post json數(shù)據(jù)的方法,非常不錯(cuò),需要的的朋友參考下2017-01-01jQuery模仿京東/天貓商品左側(cè)分類導(dǎo)航菜單效果
在京東或者是天貓上可以看到左側(cè)分類導(dǎo)航菜單,當(dāng)鼠標(biāo)滑過導(dǎo)航分類時(shí),會(huì)出現(xiàn)詳細(xì)分類模塊,鼠標(biāo)移開就會(huì)恢復(fù)默認(rèn)樣式,下面小編給大家?guī)砹嘶?mouseenter()和mouseleave()實(shí)現(xiàn)仿京東/天貓商品左側(cè)分類導(dǎo)航菜單效果,一起看看吧2016-06-06