加载中...

nextAll()


概述    .nextAll( [selector ] )

返回值:jQuery

描述:获得每个匹配元素集合中所有下面的同辈元素,选择性筛选的选择器。

  • V : 1.2.nextAll( [selector ] )

    • selector
      类型: String
      一个字符串,其中包含一个选择器表达式针对匹配元素。

如果一个jQuery对象代表了一组DOM元素,.nextAll()方法允许我们在DOM树上遍历所有元素的后继元素,并且构建一个新的匹配元素的jQuery对象。

该方法还可以接受一个可选的选择器表达式,该选择器表达式可以是任何可传给 $() 函数的选择器表达式。如果供应选择器参数,那么会先测试该元素是否满足匹配的选择器表达式。

考虑一个页面上一个简单的列表:

  1. <ul>
  2. <li>list item 1</li>
  3. <li>list item 2</li>
  4. <li class="third-item">list item 3</li>
  5. <li>list item 4</li>
  6. <li>list item 5</li>
  7. </ul>

如果我们从第三个项目开始,我们可以找到它之后的元素:

  1. $('li.third-item').nextAll().css('background-color', 'red');

执行后的结果是列表项4和5变成红色背景。 由于我们没有提供一个选择器表达式,因此这两个元素很明确的成为了结果对象中的一部分。如果我们有提供一个选择的表达式,那么在包含在结果对象之前,会先测试该元素是否满足匹配的选择器表达式。

示例

实例

查找第一个 div 后面的所有 div,并为它们添加样式。

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div { width: 80px; height: 80px; background: #abc;
  6. border: 2px solid black; margin: 10px; float: left; }
  7. div.after { border-color: red; }
  8. </style>
  9. <script src="http://code.jquery.com/jquery-latest.js"></script>
  10. </head>
  11. <body>
  12. <div>first</div>
  13. <div>sibling<div>child</div></div>
  14. <div>sibling</div>
  15. <div>sibling</div>
  16. <script>$("div:first").nextAll().addClass("after");</script>
  17. </body>
  18. </html>

运行一下

实例

查找 body 中第二个孩子元素后面的所有段落,并为它们添加样式。

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div, p { width: 60px; height: 60px; background: #abc;
  6. border: 2px solid black; margin: 10px; float: left; }
  7. .after { border-color: red; }
  8. </style>
  9. <script src="http://code.jquery.com/jquery-latest.js"></script>
  10. </head>
  11. <body>
  12. <p>p</p>
  13. <div>div</div>
  14. <p>p</p>
  15. <p>p</p>
  16. <div>div</div>
  17. <p>p</p>
  18. <div>div</div>
  19. <script>
  20. $(":nth-child(1)").nextAll("p").addClass("after");
  21. </script>
  22. </body>
  23. </html>

运行一下


还没有评论.