1-6 遍历后代
本节编程练习不计算学习进度,请电脑登录imooc.com操作

遍历后代

后代是子、孙、曾孙等等,通过 jQuery,您能够向下遍历 DOM 树,以查找元素的后代。

下面是两个用于向下遍历 DOM 树的 jQuery 方法:

children()
find()

jQuery children() 方法

获得匹配元素集合中每个元素的子元素,选择器选择性筛选。

因为就jQuery可以是一个DOM的合集对象,所以children就需要遍历每一个合集中的直接子元素了,并且最后需要构建一个新的jQuery对象。

jQuery find() 方法

1、.find()方法返回被选元素的后代元素,一路向下直到最后一个后代。

2、.find()方法允许我们能够通过查找DOM树中的这些元素的后代元素,匹配的元素将构造一个新的jQuery对象。

3、.find().children()方法是相似的,但后者只是再DOM树中向下遍历一个层级。

4、.find()方法还可以接受一个选择器表达式,该选择器表达式可以是任何可传给$()函数的选择器表达式。如果紧随兄弟匹配选择器,它将被保留在新构建的jQuery对象中;否则,它被排除在外。

这个方法用的概率相当高,除了接受一个选择器外,还可以接受一个jQuery对象,我们可以看到.find()方法的内部实际上是调用的jQuery.find 也就是sizzle的引擎选择器。

当然在高级版本中我们大多数可以这样处理:

function find(elem, selector) {
  return elem.querySelectorAll(selector);
}

通过在指定的上下文,通过querySelectorAll直接查找出元素,具体是sizzle在之前就分析过了。

任务

  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  5. <script src="http://img1.sycdn.imooc.com//down/540812440001e40e00000000.js" type="text/javascript"></script>
  6. <!-- <script type="text/javascript" src="../jquery-2.1.1.js"></script> -->
  7. <title></title>
  8. </head>
  9. <body>
  10.  
  11. <button id="test1">jQuery children方法</button>
  12. <button id="test2">模拟children方法</button>
  13.  
  14. <div></div>
  15.  
  16. <ul class="level-1">
  17. <li class="item-i">I</li>
  18. <li class="item-ii">II
  19. <ul class="level-2">
  20. <li class="item-a">A</li>
  21. <li class="item-b">B
  22. <ul class="level-3">
  23. <li class="item-1">1</li>
  24. <li class="item-2">2</li>
  25. <li class="item-3">3</li>
  26. </ul>
  27. </li>
  28. <li class="item-c">C</li>
  29. </ul>
  30. </li>
  31. <li class="item-iii">III</li>
  32. </ul>
  33.  
  34.  
  35. <script type="text/javascript">
  36.  
  37.  
  38. $("#test1").click(function(){
  39. $('.level-2').children().each(function(i,ele){
  40. $('div').append('<li>jQuery.children方法,子元素的className为:'+ ele.className + '</li>')
  41. })
  42. })
  43.  
  44. $("#test2").click(function() {
  45. function sibling(n, elem) {
  46. var matched = [];
  47. for (; n; n = n.nextSibling) { //如果存在下一个兄弟节点
  48. if (n.nodeType === 1 && n !== elem) { //是元素节点,且不是当前选择器元素
  49. matched.push(n);
  50. }
  51. }
  52. return matched;
  53. }
  54.  
  55. var ul = document.querySelectorAll('.level-2')[0];
  56.  
  57. //遍历所有元素
  58. $.each(sibling(ul.firstChild), function(i, ele) {
  59. $('div').append('<li>模拟children方法,子元素的className为:' + ele.className + '</li>')
  60. })
  61. })
  62.  
  63. </script>
  64. </body>
  65. </html>
下一节