您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)jquery中什么被譽(yù)為工廠函數(shù)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。
jquery中被譽(yù)為工廠函數(shù)的是“$()”,它本質(zhì)上就是一個(gè)DOM對(duì)象,但是它所使用的方法都封裝在了jQuery上,所以我們不能通過“$()”來使用JavaScript的方法,同樣DOM對(duì)象也不能使用jQuery上的方法。
jquery中被譽(yù)為工廠函數(shù)的是“$()”。在jQuery中,無論我們使用哪種類型的選擇符都需要從一個(gè)“$”符號(hào)和一對(duì)“()”開始。
“$”是jQuery“類”的一個(gè)別稱,$()構(gòu)造了一個(gè)jQuery對(duì)象;所以,“$()”可以叫做jQuery的構(gòu)造函數(shù)。
工廠函數(shù)“$()”本質(zhì)上就是一個(gè)DOM對(duì)象,但是它所使用的方法都封裝在了jQuery上,所以我們不能通過“$()”來使用JavaScript的方法,同樣DOM對(duì)象也不能使用jQuery上的方法。
我們以$為開始,引出整個(gè)jQuery的架構(gòu)
以jQuery的1.11.3版本舉例,$作為一個(gè)函數(shù)名出現(xiàn)的地方是在源碼的最后:
window.jQuery = window.$ = jQuery;
其中的jQuery是前面定義的一個(gè)函數(shù),在源碼第70行中出現(xiàn)
jQuery = function( selector, context ) { // The jQuery object is actually just the init constructor 'enhanced' // Need init if jQuery is called (just allow error to be thrown if not included) return new jQuery.fn.init( selector, context ); }
這個(gè)函數(shù)相當(dāng)于一個(gè)工廠函數(shù),它內(nèi)部返回了一個(gè)對(duì)象,這樣就可以不用new的方式創(chuàng)建jQuery對(duì)象了
所以new $().xxx 和 $().xxx 就沒有區(qū)別了,這也符合jQuery的設(shè)計(jì)理念“write less, do more”
在源碼第2882行中:
// Give the init function the jQuery prototype for later instantiation init.prototype = jQuery.fn;
init的原型對(duì)象替換為jQuery.fn,其實(shí)就是替換成了jQuery這個(gè)函數(shù)自己的原型對(duì)象jQuery.prototype
在源碼89行中:
jQuery.fn = jQuery.prototype
這樣做我們可以很方便的寫jQuery的擴(kuò)展方法
舉個(gè)例子:
jQuery.fn.alertMsg = function(msg){ alert('msg'); }
使用:
$().alertMsg('Hello World!');
jQuery的整體架構(gòu)到這里就差不多了
下面是一個(gè)簡(jiǎn)化版的jQuery架構(gòu),便于理解
(function () { function jQuery(selector) { return new jQuery.prototype.init(selector); } // jQuery對(duì)象的構(gòu)造函數(shù) jQuery.prototype.init = function (selector) { } // jQuery原型上的css方法 jQuery.prototype.css = function (config) { } // 將jQuery原型上的方法都放到init的原型鏈上 jQuery.prototype.init.prototype = jQuery.prototype; window.$ = window.jQuery = jQuery; })();
關(guān)系圖解:
感謝各位的閱讀!關(guān)于jquery中什么被譽(yù)為工廠函數(shù)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。