溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jquery中什么被譽為工廠函數

發布時間:2020-12-01 10:18:19 來源:億速云 閱讀:381 作者:小新 欄目:web開發

這篇文章給大家分享的是有關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中什么被譽為工廠函數

感謝各位的閱讀!關于jquery中什么被譽為工廠函數就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女