Jquery$選擇器--是如何將DOM封裝成jquery對象的2018-07-20

前言:

說到j(luò)query不得不說的就是強大的jquery的選擇器功能啦。該功能很強大,還單獨分離出來sizzle模塊供只需用到選擇器功能的朋友使用。(該篇先不說jquery選擇器的強大功能,先說說jquery是如何將DOM元素封裝成jquery對象的)

一、Dom對象和jquery對象

測試

var oBox = document.getElementById('box');

var oBox2 = document.querySelector('#box');

varBox=Box =Box=('#box');

console.log(oBox);

console.log(oBox2);

console.log($Box);

運行結(jié)果:


從中我們就可以看出區(qū)別了,$()把DOM對象封裝成jquery對象,而DOM對象也就保存在jquery[0]中,這也就是為什么我們說的把jquery對象轉(zhuǎn)化成DOM對象只需用jquery[0]或者jquery.get(0)了。

二、模擬jquery--根據(jù)id,封裝jquery對象

這里先簡化一下,看看封裝jquery對象的一部分過程

測試

varBox=Box =Box=('#box');

console.log('這是jquery對象');

console.log(公式輸入有誤/;

match = rquickExpr.exec( selector );

//console.log(match);? //正則匹配找出id的值

if ( !selector ) {? //如果selector為'',null,undefind直接退出操作

return this;

}

elem = document.getElementById(match[2]);

this[0] = elem;

this.context=document;

this.length = 1;

this.selector = selector;

return this;

}

}

jQ.fn.init.prototype = jQ.fn;

window.公式輸入有誤('#box'));? //輸出封裝的對象

②輸出結(jié)果:(火狐瀏覽器上打開的)


這里需要注意的是,chrome瀏覽器在顯示上有會些不同


jquery顯示的是類數(shù)組對象形態(tài)。

③、解析

對于上面代碼有很多看不明白的朋友建議看一下我前面寫的文章【jquery源碼】開始學習源碼之前需要解決的一些問題。

正則匹配我是直接復制了源碼中的正則,可以輸出該正則處理后的結(jié)果來看看。


三、模擬jquery--根據(jù)標簽名,封裝jquery對象

直接上代碼

  • 測試1
  • 測試2
  • 測試3
  • 測試4
  • console.log('這是jquery對象');

    var aLi1 = $('li');

    console.log(aLi1);

    console.log('------分界線------');

    (function(window,undefined){

    var jQ = function(selector,context){

    return new jQ.fn.init(selector, context);

    };

    jQ.fn = jQ.prototype = {

    jquery:'2.0.0',? ? //jquery版本號信息

    constructor: jQ,? ? //添加構(gòu)造器屬性

    length:0,? ? ? ? ? //初始length屬性

    selector:'',? ? ? ? //初始selector屬性

    init: function(selector, context){

    var match, elem;

    if ( !selector ) {? //如果selector為'',null,undefind直接退出操作

    return this;

    }

    elem = document.getElementsByTagName(selector);

    for(var i =0,len=elem.length; i

    this[i] = elem[i];

    }

    this.context=document;

    this.length = elem.length;

    this.selector = selector;

    return this;

    }

    }

    jQ.fn.init.prototype = jQ.fn;

    window.公式輸入有誤('li'));? //輸出封裝的對象

    輸出結(jié)果:


    這里只是單純的模擬,jq處理起來遠遠沒有那么簡單,jquery還進行了大量的判斷(下面的文章會繼續(xù)說這個問題)。還可以在jquery對象中發(fā)現(xiàn)prevObject屬性,該屬性保存的是上一級的查找對象。

    最后編輯于
    ?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
    【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
    平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

    友情鏈接更多精彩內(nèi)容