溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jquery中什么被譽(yù)為工廠函數(shù)

發(fā)布時(shí)間:2020-12-01 10:18:19 來源:億速云 閱讀:339 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(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)系圖解:
jquery中什么被譽(yù)為工廠函數(shù)

感謝各位的閱讀!關(guān)于jquery中什么被譽(yù)為工廠函數(shù)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(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)容。

AI