jQuery對(duì)象和原生DOM對(duì)象的相互轉(zhuǎn)換以及實(shí)現(xiàn)原理

一、前言

在前端開(kāi)發(fā)中,如果沒(méi)有用angular.js和Vue.js這類MVVM框架的話鞭莽,那么就要自己操作DOM麸祷,當(dāng)需要自己操作DOM的時(shí)候,為了兼容性和開(kāi)發(fā)效率一般都會(huì)使用封裝好的庫(kù)喷面,現(xiàn)在比較流行的庫(kù)依然是jQuery走孽。

在進(jìn)行jQuery開(kāi)發(fā)的時(shí)候,經(jīng)常會(huì)遇到的場(chǎng)景是jQuery對(duì)象轉(zhuǎn)換為原生的DOM對(duì)象以及原生DOM對(duì)象轉(zhuǎn)換為jQuery對(duì)象盒齿。轉(zhuǎn)換的方式非常簡(jiǎn)單:

  • 原生DOM對(duì)象轉(zhuǎn)jQuery對(duì)象:
var box = document.getElementById('box');
var $box = $(box);
  • jQuery對(duì)象轉(zhuǎn)原生DOM對(duì)象:
var $box = $('#box');
var box1 = $box[0];
var box2 = $box.get(0);

注:個(gè)人喜歡在jQuery對(duì)象前加“$”符號(hào)困食,加以區(qū)分jQuery對(duì)象和原生DOM對(duì)象

以上就是jQuery對(duì)和原生DOM對(duì)象的的互相轉(zhuǎn)換陷舅,是不是真的很簡(jiǎn)單呢!但是作為一個(gè)有追求的前端開(kāi)發(fā)人員待讳,僅僅知道如何用是不夠的仰剿,更要了解內(nèi)部的實(shí)現(xiàn)細(xì)節(jié)!A詹省部凑!

二、偽數(shù)組對(duì)象

在jQuery的中有一個(gè)包裝集概念涂邀,包裝集就是用偽數(shù)組實(shí)現(xiàn)的比勉。先看下正常的數(shù)組的定義及遍歷:

var arr = ['iceman' , 'mengzhe' , 'shoushou' , 'zhuzhu'];
for (var i = 0; i < arr.length; i++) {
    console.log(arr[i]);
}

輸出:


正常數(shù)組的遍歷結(jié)果.png

以上便是以字面量的方式定義了一個(gè)數(shù)組驹止,并且添加幾個(gè)簡(jiǎn)單的字符串观蜗,以及遍歷輸出每一項(xiàng)墓捻,這個(gè)在JavaScript中是再正常不過(guò)了。那么毙替,什么是偽數(shù)組呢厂画?.... 就是用對(duì)象來(lái)模擬的!

var objArr = {
    0 : 'iceman',
    1 : 'mengzhe',
    2 : 'shoushou',
    3 : 'zhuzhu',
    length : 4
}
for (var i = 0; i < $objArr.length; i++) {
    console.log($objArr[i]);
}

輸出:


偽數(shù)組的遍歷結(jié)果.png

以上代碼中以對(duì)象字面量的形式定義了一個(gè)對(duì)象objArr屎慢,這個(gè)對(duì)象就用來(lái)模擬數(shù)組忽洛,即偽數(shù)組對(duì)象,在$arr中要偽裝的數(shù)組項(xiàng)以數(shù)字0集灌、1复哆、2...為鍵。js中獲取一個(gè)對(duì)象的屬性值可以使用obj.prop或者obj['prop']唆阿,當(dāng)對(duì)象字面量中鍵是以數(shù)字開(kāi)頭的時(shí)候锈锤,用obj['prop']獲取值的時(shí)候可以不加引號(hào),即obj[prop]浅辙,在上面的實(shí)例中就是objArr[1]妄壶、objArr[2]寄狼、objArr[3]....

看到這里有沒(méi)有一種很似曾相識(shí)的感覺(jué)呢氨淌? 前面說(shuō)到盛正,jQuery對(duì)象轉(zhuǎn)原生DOM對(duì)象的其中一種方式是:jQuery對(duì)象[0]屑埋,和以上的對(duì)象字面量中鍵是數(shù)字的形式是不很像呢? 另外多說(shuō)一句摘能,jQuery對(duì)象.get(0)的內(nèi)部使用的就是jQuery對(duì)象[0]來(lái)實(shí)現(xiàn)的团搞。

三、轉(zhuǎn)換的細(xì)節(jié)

jQuery使用選擇器獲取的對(duì)象會(huì)被包裝為一個(gè)包裝集像吻,該包裝集的內(nèi)部實(shí)現(xiàn)就是使用偽數(shù)組對(duì)象:

斷點(diǎn)查看jQuery對(duì)象.png

從斷點(diǎn)的結(jié)果來(lái)看复隆,用選擇器獲取的所有的確都封裝了一個(gè)偽數(shù)組對(duì)象。所以使用$divs[0]獲取的就是$divs對(duì)象中的鍵為0的div元素惭每,即第一個(gè)div元素:

$divs中第一個(gè)元素.png

以上有四個(gè)div洪鸭,用$divs[0]獲取的是第一個(gè)仑扑,并且獲取的是原生的DOM對(duì)象,那么如果用選擇器只獲取到了一個(gè)元素镇饮,那么用$divs[0]獲取的就是該元素的原生DOM對(duì)象储藐,這就是jQuery對(duì)象轉(zhuǎn)為原生DOM對(duì)象。

有了上文的理解蛛碌,原生DOM對(duì)象轉(zhuǎn)jQuery對(duì)象理解起來(lái)就簡(jiǎn)單多了辖源,$(原生DOM對(duì)象)的方式可以將原生DOM對(duì)象轉(zhuǎn)為jQuery對(duì)象希太,其實(shí)$是一個(gè)方法酝蜒,原生的DOM對(duì)象傳入$方法中,該方法內(nèi)部對(duì)原生DOM對(duì)象做進(jìn)一步的加工堕澄, 使其成為一個(gè)包裝集霉咨,即偽數(shù)組對(duì)象。

四惊来、總結(jié)

jQuery對(duì)象和原生DOM對(duì)象的相互轉(zhuǎn)換在jQuery內(nèi)部已經(jīng)封裝的很好了棺滞,使用起來(lái)非常簡(jiǎn)單,但是了解了其實(shí)現(xiàn)的原理之后更能理解jQuery的設(shè)計(jì)哲學(xué)枉证,知其然并且知其所以然之后使用起來(lái)更得心應(yīng)手移必。在知道了用選擇器獲取的包裝集是偽數(shù)組對(duì)象之后,對(duì)于jQuery的隱式迭代也會(huì)有更好的理解秒赤,其中原理可以后面再分析憎瘸。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末幌甘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子锅风,更是在濱河造成了極大的恐慌皱埠,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件训枢,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡诀黍,警方通過(guò)查閱死者的電腦和手機(jī)仗处,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門婆誓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)也颤,“玉大人,你說(shuō)我怎么就攤上這事翅娶〗吣” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵森书,是天一觀的道長(zhǎng)谎势。 經(jīng)常有香客問(wèn)我,道長(zhǎng)猖毫,這世上最難降的妖魔是什么须喂? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任镊折,我火速辦了婚禮,結(jié)果婚禮上骂因,老公的妹妹穿的比我還像新娘赃泡。我一直安慰自己乘盼,他們只是感情好俄烁,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布页屠。 她就那樣靜靜地躺著,像睡著了一般辰企。 火紅的嫁衣襯著肌膚如雪牢贸。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,158評(píng)論 1 308
  • 那天臭增,我揣著相機(jī)與錄音竹习,去河邊找鬼。 笑死芍锚,一個(gè)胖子當(dāng)著我的面吹牛蔓榄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播甥郑,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼澜搅,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了癌瘾?” 一聲冷哼從身側(cè)響起饵溅,我...
    開(kāi)封第一講書(shū)人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎冠句,沒(méi)想到半個(gè)月后幸乒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡罕扎,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年聚唐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片壳影。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拱层,死狀恐怖弥臼,靈堂內(nèi)的尸體忽然破棺而出宴咧,到底是詐尸還是另有隱情,我是刑警寧澤径缅,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布掺栅,位于F島的核電站,受9級(jí)特大地震影響纳猪,放射性物質(zhì)發(fā)生泄漏氧卧。R本人自食惡果不足惜氏堤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一沙绝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧鼠锈,春花似錦闪檬、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至同欠,卻和暖如春样傍,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背铺遂。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工衫哥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人襟锐。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓撤逢,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子笛质,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 一泉沾、樣式篇 第1章 初識(shí)jQuery (1)環(huán)境搭建 進(jìn)入官方網(wǎng)站獲取最新的版本 http://jquery.co...
    凜0_0閱讀 3,392評(píng)論 0 44
  • 第一章 jQuery簡(jiǎn)介 1-1 jQuery簡(jiǎn)介 1.簡(jiǎn)介 2.優(yōu)勢(shì) 3.特性與工具方法 1-2 環(huán)境搭建 進(jìn)入...
    mo默22閱讀 1,587評(píng)論 0 11
  • 原文鏈接 http://blog.poetries.top/2016/10/20/review-jQuery 關(guān)注...
    程序員poetry閱讀 16,649評(píng)論 18 503
  • jQuery基礎(chǔ)(一)——樣式篇 1-2環(huán)境搭建 1-3 jQuery HelloWorld體驗(yàn) $(docume...
    croyance0601閱讀 1,086評(píng)論 0 8
  • 個(gè)人為求生結(jié)果了欲置自己死地的對(duì)手,這正當(dāng)嗎妇押?如果為了錢殺人跷究,比如升職、偷獵等等敲霍,聽(tīng)起來(lái)合理嗎俊马?為...
    源錦閱讀 452評(píng)論 0 0