js 獲取元素所有兄弟節(jié)點(diǎn)的實(shí)現(xiàn)方法
比如一個(gè)ul里面有10個(gè)li,而第3個(gè)li上有特殊的樣式(比如顏色為紅色,其他為黑色)。我想把其他所有l(wèi)i——不包括紅的li——的顏色也設(shè)為紅色,此時(shí),就需要獲得紅li的所有兄弟節(jié)點(diǎn)。
兄弟,就是和你平輩的,既不是上一級(jí)也不是下一級(jí),而且可能有比你大的(兄),也可能比你小(弟)。兄弟節(jié)點(diǎn)同理,下面是一個(gè)常規(guī)的獲取兄弟節(jié)點(diǎn)的辦法。
代碼如下
function siblings(elm) {
var a = [];
var p = elm.parentNode.children;
for(var i =0,pl= p.length;i<pl;i++) {
if(p[i] !== elm) a.push(p[i]);
}
return a;
}
思路:先獲取此元素的父節(jié)點(diǎn)的所有子節(jié)點(diǎn),因?yàn)樗凶庸?jié)點(diǎn)也包括此元素自己,所以要從結(jié)果中去掉自己。
還有另外一種看起來(lái)比較奇特的方法,是jQuery里面獲取兄弟節(jié)點(diǎn)的源碼:
代碼如下
function sibling( elem ) {
var r = [];
var n = elem.parentNode.firstChild;
for ( ; n; n = n.nextSibling ) {
if ( n.nodeType === 1 && n !== elem ) {
r.push( n );
}
}
return r;
}
思路:先找到此元素的父節(jié)點(diǎn)的第一個(gè)子節(jié)點(diǎn),然后循環(huán)查找此節(jié)點(diǎn)的下一個(gè)兄弟節(jié)點(diǎn),一直到查找完畢。
我很奇怪為什么jQuery會(huì)使用這個(gè)方法,難道這個(gè)方法比第一個(gè)方法效率更高?
經(jīng)過(guò)我初步測(cè)試——1500多個(gè)li,上面兩個(gè)方法效率幾乎無(wú)差別,都是幾毫秒內(nèi)就獲取成功了。測(cè)試環(huán)境是chrome與firefox。
如果有獲取所有兄弟節(jié)點(diǎn)的需求,可以使用以上任一方法。
當(dāng)然,我會(huì)在以后的使用過(guò)程中驗(yàn)證以上兩個(gè)方法,如果有出入,再更新吧。
JQUERY的父,子,兄弟節(jié)點(diǎn)查找方法
jQuery.parent(expr) 找父親節(jié)點(diǎn),可以傳入expr進(jìn)行過(guò)濾,比如$("span").parent()或者$("span").parent(".class")
jQuery.parents(expr),類(lèi)似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素
jQuery.children(expr).返回所有子節(jié)點(diǎn),這個(gè)方法只會(huì)返回直接的孩子節(jié)點(diǎn),不會(huì)返回所有的子孫節(jié)點(diǎn)
jQuery.contents(),返回下面的所有內(nèi)容,包括節(jié)點(diǎn)和文本。這個(gè)方法和children()的區(qū)別就在于,包括空白文本,也會(huì)被作為一個(gè)
jQuery對(duì)象返回,children()則只會(huì)返回節(jié)點(diǎn)
jQuery.prev(),返回上一個(gè)兄弟節(jié)點(diǎn),不是所有的兄弟節(jié)點(diǎn)
jQuery.prevAll(),返回所有之前的兄弟節(jié)點(diǎn)
jQuery.next(),返回下一個(gè)兄弟節(jié)點(diǎn),不是所有的兄弟節(jié)點(diǎn)
jQuery.nextAll(),返回所有之后的兄弟節(jié)點(diǎn)
jQuery.siblings(),返回兄弟姐妹節(jié)點(diǎn),不分前后
jQuery.find(expr),跟jQuery.filter(expr)完全不一樣。jQuery.filter()是從初始的jQuery對(duì)象集合中篩選出一部分,而jQuery.find()
的返回結(jié)果,不會(huì)有初始集合中的內(nèi)容,比如$("p"),find("span"),是從<p>元素開(kāi)始找<span>,等同于$("p span")
以上這篇js 獲取元素所有兄弟節(jié)點(diǎn)的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例
這篇文章主要介紹了bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
js下拉菜單語(yǔ)言選項(xiàng)簡(jiǎn)單實(shí)現(xiàn)
大家對(duì)下拉菜單并不陌生吧,下面為大家介紹下使用js實(shí)現(xiàn)下拉菜單語(yǔ)言選項(xiàng),具體實(shí)現(xiàn)如下,喜歡的朋友可以看看2013-09-09
Javascript驗(yàn)證用戶(hù)輸入U(xiǎn)RL地址是否為空及格式是否正確
這篇文章主要介紹了Javascript驗(yàn)證用戶(hù)輸入U(xiǎn)RL地址是否為空及格式是否正確,很實(shí)用,需要的朋友可以參考下2014-10-10
Javascript實(shí)現(xiàn)信息滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Javascript實(shí)現(xiàn)信息滾動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
Base64(二進(jìn)制)圖片編碼解析及在各種瀏覽器的兼容性處理
這篇文章主要介紹了Base64(二進(jìn)制)圖片編碼解析及在各種瀏覽器的兼容性處理,需要的朋友可以參考下2017-02-02

