新聞中心
小編給大家分享一下jquery中構(gòu)造函數(shù)是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
jQuery是面向?qū)ο蟮膉s庫因此它也具備構(gòu)造函數(shù)的功能,它可通過原型及init()函數(shù)構(gòu)成構(gòu)造函數(shù),而且jQuery實(shí)現(xiàn)的構(gòu)造函數(shù)不需要用new來實(shí)例化對(duì)象
jquery中的構(gòu)造函數(shù)充分的運(yùn)用了javascript語言的動(dòng)態(tài)性。由于對(duì)行參的類型及個(gè)數(shù)沒有嚴(yán)格的要求,因此一個(gè)函數(shù)可以實(shí)現(xiàn)多種功能的需求。
jQuery是一種面向?qū)ο蟮膉s庫,也含有構(gòu)造函數(shù)。每次調(diào)用jQuery方法時(shí)就會(huì)實(shí)例化一個(gè)jQeury對(duì)象,但是jQuery的寫法卻更加高明。
在ECMA標(biāo)準(zhǔn)定義JS中的對(duì)象:無序?qū)傩缘募?,其屬性可以包含基本值、?duì)象或者函數(shù)??梢院?jiǎn)單理解為JS的對(duì)象是一組無序的值,其中的屬性或方法都有一個(gè)名字,根據(jù)這個(gè)名字可以訪問相映射的值,這個(gè)值可以是基本值,對(duì)象或者是方法
例:JavaScript中的構(gòu)造函數(shù)案例
效果圖:
接下來再看看jQuery中構(gòu)造函數(shù)的寫法
var jQuery = function(selector, context) { return new jQuery.fn.init(selector, context, rootjQuery); } jQuery.fn = jQuery.prototype = { init: function (selector, context, rootjQuery) { // ... } } jQuery.fn.init.prototype = jQuery.fn;
以上代碼就是jQuery構(gòu)造函數(shù)中的關(guān)鍵代碼,可以看出在jQuery中真正的構(gòu)造函數(shù)是init方法,當(dāng)我們調(diào)用jQuery時(shí)會(huì)返回new init()的結(jié)果而不直接new jQuery()。即在對(duì)象實(shí)例化的時(shí)候就沒必要new jQuery()
jQuery.fn = jQuery.prototype = {...} jQuery.fn.init.prototype = jQuery.fn;
說明函數(shù)是jQuery的原型對(duì)象,通過它實(shí)現(xiàn)了對(duì)象的實(shí)例化功能。最后再把jQuery的原型對(duì)象復(fù)值給init()原型對(duì)象,所以init()函數(shù)就具備了jQuery中原型的所有方法
以上是jquery中構(gòu)造函數(shù)是什么的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道!
文章標(biāo)題:jquery中構(gòu)造函數(shù)是什么-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://www.dlmjj.cn/article/gposp.html