欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 獲取元素所有兄弟節(jié)點的實現(xiàn)方法

 更新時間:2016年09月06日 15:16:42   投稿:jingxian  
下面小編就為大家?guī)硪黄猨s 獲取元素所有兄弟節(jié)點的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

比如一個ul里面有10個li,而第3個li上有特殊的樣式(比如顏色為紅色,其他為黑色)。我想把其他所有l(wèi)i——不包括紅的li——的顏色也設為紅色,此時,就需要獲得紅li的所有兄弟節(jié)點。

兄弟,就是和你平輩的,既不是上一級也不是下一級,而且可能有比你大的(兄),也可能比你?。ǖ埽?。兄弟節(jié)點同理,下面是一個常規(guī)的獲取兄弟節(jié)點的辦法。

代碼如下

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é)點的所有子節(jié)點,因為所有子節(jié)點也包括此元素自己,所以要從結果中去掉自己。

還有另外一種看起來比較奇特的方法,是jQuery里面獲取兄弟節(jié)點的源碼:

代碼如下

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é)點的第一個子節(jié)點,然后循環(huán)查找此節(jié)點的下一個兄弟節(jié)點,一直到查找完畢。

我很奇怪為什么jQuery會使用這個方法,難道這個方法比第一個方法效率更高?

經(jīng)過我初步測試——1500多個li,上面兩個方法效率幾乎無差別,都是幾毫秒內(nèi)就獲取成功了。測試環(huán)境是chrome與firefox。

如果有獲取所有兄弟節(jié)點的需求,可以使用以上任一方法。

當然,我會在以后的使用過程中驗證以上兩個方法,如果有出入,再更新吧。

JQUERY的父,子,兄弟節(jié)點查找方法

jQuery.parent(expr) 找父親節(jié)點,可以傳入expr進行過濾,比如$("span").parent()或者$("span").parent(".class")

jQuery.parents(expr),類似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素

jQuery.children(expr).返回所有子節(jié)點,這個方法只會返回直接的孩子節(jié)點,不會返回所有的子孫節(jié)點

jQuery.contents(),返回下面的所有內(nèi)容,包括節(jié)點和文本。這個方法和children()的區(qū)別就在于,包括空白文本,也會被作為一個

jQuery對象返回,children()則只會返回節(jié)點

jQuery.prev(),返回上一個兄弟節(jié)點,不是所有的兄弟節(jié)點

jQuery.prevAll(),返回所有之前的兄弟節(jié)點

jQuery.next(),返回下一個兄弟節(jié)點,不是所有的兄弟節(jié)點

jQuery.nextAll(),返回所有之后的兄弟節(jié)點

jQuery.siblings(),返回兄弟姐妹節(jié)點,不分前后

jQuery.find(expr),跟jQuery.filter(expr)完全不一樣。jQuery.filter()是從初始的jQuery對象集合中篩選出一部分,而jQuery.find()

的返回結果,不會有初始集合中的內(nèi)容,比如$("p"),find("span"),是從<p>元素開始找<span>,等同于$("p span")

以上這篇js 獲取元素所有兄弟節(jié)點的實現(xiàn)方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

  • JavaScript對象原型鏈原理詳解

    JavaScript對象原型鏈原理詳解

    這篇文章主要介紹了JavaScript對象原型鏈原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • 基于BootStrap的前端分頁帶省略號和上下頁效果

    基于BootStrap的前端分頁帶省略號和上下頁效果

    這篇文章主要介紹了基于BootStrap的前端分頁帶省略號和上下頁效果,需要的朋友可以參考下
    2017-05-05
  • javascript 尋找錯誤方法整理

    javascript 尋找錯誤方法整理

    為了以后能快速尋找到這方面的錯誤,節(jié)約更多的時間,下面將問題的解決方法整理了一下
    2014-06-06
  • JavaScript多線程的實現(xiàn)方法

    JavaScript多線程的實現(xiàn)方法

    以下內(nèi)容基于IE中GIF的onload事件的基礎上,故所有測試IE only
    2007-05-05
  • 使用JavaScript和CSS實現(xiàn)簡單的字符計數(shù)器

    使用JavaScript和CSS實現(xiàn)簡單的字符計數(shù)器

    在本文中,你將學習如何使用?JavaScript?創(chuàng)建字符計數(shù)器。計數(shù)的數(shù)字可以在小顯示屏中看到。文中示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2022-08-08
  • OpenLayers實現(xiàn)點要素圖層的聚合顯示的方法

    OpenLayers實現(xiàn)點要素圖層的聚合顯示的方法

    在很多情況下,點要素圖層中的要素數(shù)量可能會成百上千,如果一個點要素圖層中的點數(shù)量很多,我們就會采取圖層聚合的方式對其進行處理,本文就來介紹一下,感興趣的可以了解一下
    2021-09-09
  • JavaScript代碼實現(xiàn)春晚劉謙魔術的模擬程序

    JavaScript代碼實現(xiàn)春晚劉謙魔術的模擬程序

    昨晚春晚上劉謙的兩個魔術表演都非常精彩,尤其是第二個魔術,他演繹了經(jīng)典的約瑟夫環(huán)問題!約瑟夫環(huán)是一個經(jīng)典的數(shù)學問題,本文給出了完整的 JavaScript 代碼實現(xiàn),感興趣的同學可以自己動手實現(xiàn)一下
    2024-02-02
  • bootstrap柵格系統(tǒng)示例代碼分享

    bootstrap柵格系統(tǒng)示例代碼分享

    這篇文章主要為大家詳細介紹了bootstrap柵格系統(tǒng)示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 最新評論