亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery構造函數init參數分析

2019-11-20 12:29:58
字體:
來源:轉載
供稿:網友

在我的上一篇隨筆里面分析了jQuery的構造函數,jQuery對象中有一個原型方法init才是是真正的構造函數,通過init的原型對象跟jQuery的原型對象保持引用關系使得init的實例可以正常調用jQuery的原型方法,就好像是jQuery的實例一樣。下面就來看看init這個幕后的構造函數是怎么寫的:

init: function( selector, context, rootjQuery ) {...}

可以看到這個方法接受3個參數,其前兩個參數是jQuery方法傳遞過來的

var jQuery = function( selector, context ) {// The jQuery object is actually just the init constructor 'enhanced'return new jQuery.fn.init( selector, context, rootjQuery );},

Selector原則上可以輸入任意值,但并不是所有值都是有意義的,只有undefined、DOM 元素、字符串、函數、jQuery 對象、普通 JavaScript 對象這幾種類型是有效的,這個參數是通常是填寫的但是不填寫也不會報錯

復制代碼 代碼如下:

console.log($());
//[constructor: function, init: function, selector: "", jquery: "1.7.1", size: function…]

Context作為執行上下文或者叫執行范圍可以不傳入,或者傳入 DOM 元素、jQuery 對象、普通 JavaScript 對象之一

參數 rootjQuery:包含了 document 對象的 jQuery 對象,用于 document.getElementById() 查找失敗、selector 是選擇器表達式且未指定 context、selector 是函數的情況,其實就是$(document)。

下面根據參數的不同分為12種情況逐個討論

1.selector 可以轉換為false

// Handle $(""), $(null), or $(undefined)if ( !selector ) {return this;}

源碼中的注釋已經寫得很清楚了,當是這三種情況時直接return不進行任何處理

2.參數 selector 是 DOM 元素

例如: $(document)這種寫法

// Handle $(DOMElement)if ( selector.nodeType ) {this.context = this[0] = selector;this.length = 1;return this;}

只要是dom元素肯定有節點類型,然后把這個節點變成jquery對象的第一個元素并且賦值給上下文context,length屬性是jQuery的原型屬性默認為0

// The default length of a jQuery object is 0

length: 0,
這里有了一個元素之后就把length屬性修改為1。return this 操作使得函數執行后的結果依然是jQuery對象這樣就可以實現類似$(document).each()這樣的鏈式調用了。最終得到的類似這樣的{0:document,context:document,length:1....}對象,其實所有的情況最后都會變成這種形式的對象,除了jQuery原型屬性和方法之外就是獲取的dom節點并且按照阿拉伯數字依次排列,所以我們可以使用$(selector)[0]的形式代替$(selector).get(0)來獲取dom對象。例如:

<!doctype html><html>  <head>   <title></title>  </head>  <body>    <div></div>    <div></div>    <div></div>  </body>  <script src='jquery-1.7.1.js'></script>  <script>   console.log($('div'));/*[div, div, div, prevObject: jQuery.fn.jQuery.init[1], context: document, selector: "div", constructor: function, init: function…]0: div1: div2: divcontext: documentlength: 3prevObject: jQuery.fn.jQuery.init[1]__proto__: jQuery[0]selector: "div".*/  </script></html>

3.參數是特殊的字符串“body”

由于body元素在一個文檔對象中只有一個所以單獨列出來處理

// The body element only exists once, optimize finding itif ( selector === "body" && !context && document.body ) {this.context = document;this[0] = document.body;this.selector = selector;this.length = 1;return this;}

這里有3個條件必須同時滿足,第二個必須沒有上下文的條件我也不是太理解,$(‘body',document)這樣的看起來很正常的寫法也會被這種情況“忽視”     

 console.log($('body',document)); /* jQuery.fn.jQuery.init[1]0: bodycontext: documentlength: 1prevObject: jQuery.fn.jQuery.init[1]selector: "body"__proto__: jQuery[0]*/

雖然和$('body')的結果是一樣的,但是卻被當做兩種情況來看待,可能是因為body只有一個上下文只能是document沒有必要添加吧,否則又要判斷上下文是不是document。第三個條件是保證document.body必須存在,那么什么情況下會前兩個情況滿足document.body又不存在呢?首先就是js代碼先于html代碼加載時會出現這個是初學者經常會犯的錯誤,通常我們要寫成:

$(function(){...})

或者

$(document).ready(function(){...})
 
其實這兩個是一樣的調取的是一個方法,dom加載這一塊以后在分析。對此我們可以做個測試html代碼如下:

<!doctype html> <html>   <head>    <title></title>     <script src='jquery-1.7.1.js'></script>    <script>        $('body')   </script>   </head>   <body>     <div></div>     <div></div>     <div></div>   </body> </html>

然后再jQuery源代碼里面輸出selector、context和document.body

console.log(selector+context+document.body);// The body element only exists once, optimize finding itif ( selector === "body" && !context && document.body ) {this.context = document;this[0] = document.body;this.selector = selector;this.length = 1;return this;}

雖然我們只寫了一個其實執行了四次,只有最后一次才是是我們調用后的結果,最后一次的結果是bodyundefinednull這個時候前兩個就是滿足的但是最后一個是null?;叵肫鸬谝黄猨Query總體架構架構里面undefined會被重新,那么document.body會不會被重寫為null呢?當我嘗試在代碼中修改時就會報錯看來是不會的,那這個條件就是預防沒有加載html就執行的情況吧

第四種是除了上述的字符串情況之外的其他字符串,情況比較多放在下一篇吧。

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕亚洲一区二区三区| 欧美主播福利视频| 久久久999成人| 国产日韩欧美综合| 日韩一区二区三区xxxx| 国产成人综合一区二区三区| 在线视频免费一区二区| 国产精品wwwwww| 青草青草久热精品视频在线观看| 91在线视频成人| 一级做a爰片久久毛片美女图片| 日本高清+成人网在线观看| 久久精品中文字幕电影| 国产精品免费久久久| 国产精品久久77777| 91久久在线视频| 中文国产成人精品久久一| 欧洲成人免费aa| 91精品中文在线| 欧美极度另类性三渗透| 欧美激情精品久久久久久蜜臀| 久久精品视频导航| 亚洲第一福利视频| 国产欧美va欧美va香蕉在线| 欧美大片免费看| 国产精品久久久久久久av大片| 美女久久久久久久| 正在播放欧美一区| 国产成人精品在线观看| 日本高清不卡在线| 国产精品99久久久久久久久| 国产噜噜噜噜噜久久久久久久久| 国产一区二区三区在线| 欧美肥臀大乳一区二区免费视频| 国产日产欧美a一级在线| 国产欧美日韩丝袜精品一区| 久久综合九色九九| 国产精品国产亚洲伊人久久| 青草热久免费精品视频| 日韩av电影在线免费播放| 欧美丰满老妇厨房牲生活| 国内精品久久久久影院优| 欧美中文在线观看| 尤物九九久久国产精品的分类| 91免费在线视频网站| 国产91精品久久久| 亚洲精品美女久久久久| 日韩欧美在线免费观看| 日韩精品在线播放| 亚洲男人的天堂在线播放| 国产日韩精品在线| 日韩在线免费观看视频| 综合136福利视频在线| 欧美视频在线视频| 欧美日韩性视频在线| 91夜夜揉人人捏人人添红杏| 欧美孕妇性xx| 欧美另类交人妖| 国产丝袜一区视频在线观看| 久久精品国产久精国产思思| 日韩国产在线播放| 亚洲黄色免费三级| 热99精品里视频精品| 精品免费在线视频| 国产精品视频公开费视频| 伊人久久久久久久久久久| 中文字幕国内精品| 日韩精品日韩在线观看| 日韩欧美精品网站| 国产精品99一区| 欧美精品videossex88| 久久久精品网站| 国产亚洲aⅴaaaaaa毛片| 久久久97精品| 国产精品久久久久久久久男| 国产一区二区动漫| 日韩av不卡电影| 国产精品第2页| 91精品国产自产91精品| 午夜欧美大片免费观看| 热99精品里视频精品| 精品成人乱色一区二区| 91系列在线观看| 国产精品亚洲第一区| 久久久久在线观看| 久久夜色精品国产亚洲aⅴ| 18久久久久久| 欧美激情国内偷拍| 日韩精品中文字幕有码专区| 国产精品久久久久久五月尺| 国产在线观看精品一区二区三区| 日韩欧美在线国产| 亚洲综合在线中文字幕| 日韩av一区在线| 国产精品视频免费在线| 国产精品一区二区三区毛片淫片| 欧美成人精品一区二区三区| 久久久精品国产一区二区| 国产成人综合一区二区三区| 欧美xxxx做受欧美.88| 欧美日韩精品在线视频| 国产亚洲视频在线| 91av在线影院| 亚洲人成在线一二| 成人av在线天堂| 成人综合网网址| 高跟丝袜欧美一区| 国产成人精品国内自产拍免费看| 在线免费观看羞羞视频一区二区| 在线观看欧美www| 国产在线不卡精品| 97国产在线视频| 亚洲第一黄色网| 欧美激情xxxx性bbbb| 国产精品久久久久久av| 亚洲欧美中文日韩v在线观看| 91精品视频在线| 欧美中文字幕在线| 日本不卡视频在线播放| 久久91亚洲精品中文字幕| 粗暴蹂躏中文一区二区三区| 麻豆乱码国产一区二区三区| 一区二区三区四区精品| 超碰97人人做人人爱少妇| 欧美精品激情在线观看| 免费av在线一区| 久热精品视频在线观看一区| 亚洲专区中文字幕| 国产亚洲精品美女久久久久| 国产日韩精品视频| 高清一区二区三区四区五区| 91国产高清在线| 视频在线一区二区| 色无极影院亚洲| 色综合天天综合网国产成人网| 亚洲精品网站在线播放gif| 91色琪琪电影亚洲精品久久| 亚洲综合成人婷婷小说| 久久久久久网址| 亚洲一区美女视频在线观看免费| 欧美午夜片欧美片在线观看| 色综合久久中文字幕综合网小说| 欧美精品一区二区三区国产精品| 色哟哟网站入口亚洲精品| 久久亚洲电影天堂| 亚洲国产精品999| 欧美日本国产在线| 欧美日韩国产123| 精品无人区太爽高潮在线播放| 国产精品视频午夜| 96pao国产成视频永久免费| 欧洲午夜精品久久久| 日韩中文字幕在线观看| 亚洲人成网站在线播| 亚洲国产精品久久久久久| 日韩精品免费在线播放| 亚洲国产精品一区二区三区| 日韩欧美成人精品| 精品无码久久久久久国产| 国产精品国产自产拍高清av水多| 欧美日韩亚洲精品一区二区三区| 欧美精品福利视频| 日韩av色综合| 国产日本欧美一区二区三区|