這篇文章給大家分享的是有關jquery中什么被譽為工廠函數的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
jquery中被譽為工廠函數的是“$()”,它本質上就是一個DOM對象,但是它所使用的方法都封裝在了jQuery上,所以我們不能通過“$()”來使用JavaScript的方法,同樣DOM對象也不能使用jQuery上的方法。
jquery中被譽為工廠函數的是“$()”。在jQuery中,無論我們使用哪種類型的選擇符都需要從一個“$”符號和一對“()”開始。
“$”是jQuery“類”的一個別稱,$()構造了一個jQuery對象;所以,“$()”可以叫做jQuery的構造函數。
工廠函數“$()”本質上就是一個DOM對象,但是它所使用的方法都封裝在了jQuery上,所以我們不能通過“$()”來使用JavaScript的方法,同樣DOM對象也不能使用jQuery上的方法。
我們以$為開始,引出整個jQuery的架構
以jQuery的1.11.3版本舉例,$作為一個函數名出現的地方是在源碼的最后:
window.jQuery = window.$ = jQuery;
其中的jQuery是前面定義的一個函數,在源碼第70行中出現
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 ); }
這個函數相當于一個工廠函數,它內部返回了一個對象,這樣就可以不用new的方式創建jQuery對象了
所以new $().xxx 和 $().xxx 就沒有區別了,這也符合jQuery的設計理念“write less, do more”
在源碼第2882行中:
// Give the init function the jQuery prototype for later instantiation init.prototype = jQuery.fn;
init的原型對象替換為jQuery.fn,其實就是替換成了jQuery這個函數自己的原型對象jQuery.prototype
在源碼89行中:
jQuery.fn = jQuery.prototype
這樣做我們可以很方便的寫jQuery的擴展方法
舉個例子:
jQuery.fn.alertMsg = function(msg){ alert('msg'); }
使用:
$().alertMsg('Hello World!');
jQuery的整體架構到這里就差不多了
下面是一個簡化版的jQuery架構,便于理解
(function () { function jQuery(selector) { return new jQuery.prototype.init(selector); } // jQuery對象的構造函數 jQuery.prototype.init = function (selector) { } // jQuery原型上的css方法 jQuery.prototype.css = function (config) { } // 將jQuery原型上的方法都放到init的原型鏈上 jQuery.prototype.init.prototype = jQuery.prototype; window.$ = window.jQuery = jQuery; })();
關系圖解:
感謝各位的閱讀!關于jquery中什么被譽為工廠函數就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。