国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

js 獲取元素所有兄弟節點實例

2019-11-08 20:06:07
字體:
來源:轉載
供稿:網友
現在在js中要獲取兄弟節點有兩種常用的方法,一種是利用js來遍歷,另一種是利用jquery來獲取,下面小編來給大家介紹一下.

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

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

 代碼如下復制代碼

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;}

思路:先獲取此元素的父節點的所有子節點,因為所有子節點也包括此元素自己,所以要從結果中去掉自己。

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

 代碼如下復制代碼

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; }

思路:先找到此元素的父節點的第一個子節點,然后循環查找此節點的下一個兄弟節點,一直到查找完畢。

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

經過我初步測試——1500多個li,上面兩個方法效率幾乎無差別,都是幾毫秒內就獲取成功了。測試環境是ChromeFirefox

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

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

JQUERY的父,子,兄弟節點查找方法

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

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

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

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

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

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

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

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

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

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

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

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


上一篇:PAT甲級1116

下一篇:使用CoordinatorLayout

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 八宿县| 化州市| 泊头市| 榕江县| 晋州市| 临武县| 互助| 德江县| 綦江县| 晋宁县| 乌苏市| 荣昌县| 隆尧县| 邯郸县| 巨鹿县| 安西县| 梁河县| 武定县| 始兴县| 平武县| 鄂伦春自治旗| 那坡县| 姜堰市| 嘉义市| 韶关市| 泾川县| 民乐县| 基隆市| 新乐市| 育儿| 滨州市| 皮山县| 牙克石市| 大关县| 鄂州市| 广宁县| 拉萨市| 香港 | 山阴县| 县级市| 巴楚县|