jQuery nextUntil() 方法

实例

返回样式类名为 "start" 和 "stop" 的两个 <li> 元素之间的所有同级元素:

  1. $(document).ready(function(){
  2. $("li.start").nextUntil("li.stop").css({"color": "red", "border": "2px solid red"});
  3. });

结果:

    ul (父级)
  • li (同级)
  • li (sibling)
  • li (带有 class=”start” 的同级)
  • li (同级)
  • li (同级)
  • li (同级)
  • li (带有 class=”stop” 的同级)

完整代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .siblings * {
  6. display: block;
  7. border: 2px solid lightgrey;
  8. color: lightgrey;
  9. padding: 5px;
  10. margin: 15px;
  11. }
  12. </style>
  13. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  14. <script>
  15. $(document).ready(function(){
  16. $("li.start").nextUntil("li.stop").css({"color": "red", "border": "2px solid red"});
  17. });
  18. </script>
  19. </head>
  20. <body>
  21. <div style="width:500px;" class="siblings">
  22. <ul>ul (父级)
  23. <li>li (同级)</li>
  24. <li>li (同级)</li>
  25. <li class="start">li (class="start" 的同级)</li>
  26. <li>li (class="start" 的 li 的下一个同级)</li>
  27. <li>li (class="start" 的 li 的下一个同级)</li>
  28. <li>li (class="start" 的 li 的下一个同级)</li>
  29. <li class="stop">li (class="stop" 的同级)</li>
  30. </ul>
  31. </div>
  32. <p>在本例中,我们返回样式类名为 "start" 的 li 元素和样式类名为 "stop" 的 li 元素之间的所有下一个同级元素。</p>
  33. </body>
  34. </html>

定义与用法

nextUntil() 方法返回 选择器停止选择器 之间的所有同级元素。

同级元素是共享同一父元素的元素。

DOM 树: 该方法沿着 DOM 元素的同级向前遍历。

注意: 如果两个参数都为空,则此方法将返回所有下一个同级元素(与 nextAll() 方法相同)。

相关方法:

  • next() - 返回所选元素的下一个同级元素
  • nextAll() - 返回所选元素的所有下一个同级元素

语法

  1. $(selector).nextUntil(stop,filter)
参数描述
stop可选。选择器表达式、元素或 jQuery 对象,指示在何处停止搜索下一个匹配的同级元素
filter可选。指定一个选择器表达式,以缩小对 selectorstop 之间同级元素的搜索范围
注意: 要返回多个同级,请用逗号分隔每个表达式

更多实例

缩小搜索范围

使用这两个参数过滤搜索两个参数之间的下一个同级元素。

返回多个同级元素

如何在两个参数之间返回多个同级元素。

DOM

使用 DOM 元素而不是选择器返回所有同级元素,并返回两个给定参数。

将 DOM 与这两个参数一起使用

使用 DOM 元素而不是选择器和这两个参数来过滤两个参数之间的下一个同级搜索。

分类导航