当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


JQuery .siblings()用法及代码示例


用法
.siblings(  [selector ] ) => jQuery

说明:获取匹配元素集中每个元素的兄弟姐妹,可选地由选择器过滤。

  • 添加的版本:1.0.siblings( [selector ] )

    • selector
      类型:Selector
      一个字符串,包含一个选择器表达式来匹配元素。

给定一个表示一组 DOM 元素的 jQuery 对象,.siblings() 方法允许我们在 DOM 树中搜索这些元素的兄弟,并从匹配的元素构造一个新的 jQuery 对象。

该方法可选择接受与我们可以传递给$() 函数的类型相同的选择器表达式。如果提供了选择器,则将通过测试它们是否匹配来过滤元素。

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

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

如果我们从第三项开始,我们可以找到它的兄弟:

$( "li.third-item" ).siblings().css( "background-color", "red" );

此调用的结果是项目 1、2、4 和 5 后面的红色背景。由于我们不提供选择器表达式,所有兄弟姐妹都是对象的一部分。如果我们提供了一项,则只会包括这四项中匹配的项。

原始元素不包含在兄弟元素中,当我们希望在 DOM 树的特定级别查找所有元素时,记住这一点很重要。但是,如果原始集合包含多个元素,则它们可能是相互的兄弟,并且都会被找到。如果您需要兄弟姐妹的独占列表,请使用 $collection.siblings().not($collection)

例子:

在 3 个列表中找到所有黄色 li 元素的唯一兄弟(如果合适,包括其他黄色 li 元素)。

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>siblings demo</title>
  <style>
  ul {
    float: left;
    margin: 5px;
    font-size: 16px;
    font-weight: bold;
  }
  p {
    color: blue;
    margin: 10px 20px;
    font-size: 16px;
    padding: 5px;
    font-weight: bolder;
  }
  .hilite {
    background: yellow;
  }
  </style>
  <script src="https://code.jquery.com/jquery-3.5.0.js"></script>
</head>
<body>
 
<ul>
  <li>One</li>
  <li>Two</li>
  <li class="hilite">Three</li>
  <li>Four</li>
</ul>
 
<ul>
  <li>Five</li>
  <li>Six</li>
  <li>Seven</li>
</ul>
 
<ul>
  <li>Eight</li>
  <li class="hilite">Nine</li>
  <li>Ten</li>
  <li class="hilite">Eleven</li>
</ul>
 
<p>Unique siblings: <b></b></p>
 
<script>
var len = $( ".hilite" ).siblings()
  .css( "color", "red" )
  .length;
$( "b" ).text( len );
</script>
 
</body>
</html>

演示:

查找每个 div 的类 "selected" 的所有兄弟姐妹。

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>siblings demo</title>
  <script src="https://code.jquery.com/jquery-3.5.0.js"></script>
</head>
<body>
 
<div><span>Hello</span></div>
<p class="selected">Hello Again</p>
<p>And Again</p>
 
<script>
$( "p" ).siblings( ".selected" ).css( "background", "yellow" );
</script>
 
</body>
</html>

演示:

相关用法


注:本文由纯净天空筛选整理自jquery.com大神的英文原创作品 .siblings()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。