js或jquery如何獲取父級、子級、兄弟元素(包括祖級、孫級等)

  • 原生javascript方法:
var a = document.getElementById("dom");
      del_space(a); //清理空格
      var b = a.childNodes; //獲取a的全部子節(jié)點;
      var c = a.parentNode; //獲取a的父節(jié)點;
      var d = a.nextSibling; //獲取a的下一個兄弟節(jié)點
      var e = a.previousSibling; //獲取a的上一個兄弟節(jié)點
      var f = a.firstChild; //獲取a的第一個子節(jié)點
      var g = a.lastChild; //獲取a的最后一個子節(jié)點
  • jQuery方法:
jQuery.parent(expr) //找父親節(jié)點,可以傳入expr進行過濾,比如$("span").parent()或者$("span").parent(".class")

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

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

jQuery.contents() //返回下面的所有內容,包括節(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()的返回結果,不會有初始集合中的內容,比如$("p"),find("span"),是從p元素開始找,等同于$("p span").
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容