前言:
說到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源碼】開始學(xué)習(xí)源碼之前需要解決的一些問題究履。
正則匹配我是直接復(fù)制了源碼中的正則滤否,可以輸出該正則處理后的結(jié)果來看看。
三最仑、模擬jquery--根據(jù)標簽名顽聂,封裝jquery對象
直接上代碼
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屬性蜜葱,該屬性保存的是上一級的查找對象全景。