选择元素有两个使用 jQuery 的特定子元素

Posted

技术标签:

【中文标题】选择元素有两个使用 jQuery 的特定子元素【英文标题】:Select element has two specific children using jQuery 【发布时间】:2019-08-09 14:07:24 【问题描述】:

我想通过匹配两个孩子来选择父母。 我的代码:

$('span:contains("11:00am"), span.name:contains("Tom")').parents("a").css("background-color","rgb(255, 255, 255)");
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<a style="background-color: rgb(0, 0, 0);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Tom</span>
</a>
<a style="background-color: rgb(0, 0, 0);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Jack</span>
</a>

但是,这将选择 TomJack 的时间。

【问题讨论】:

【参考方案1】:

你需要选择a标签,然后使用:has()选择器来过滤元素有特定的孩子。

$('a:has(span:contains("11:00am")):has(span.name:contains("Tom"))')

$('a:has(span:contains("11:00am")):has(span.name:contains("Tom"))').css("background-color","rgb(255, 255, 255)");
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<a style="background-color: rgb(0, 0, 0);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Tom</span>
</a>
<a style="background-color: rgb(0, 0, 0);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Jack</span>
</a>

【讨论】:

:has() 选择器是我正在寻找的,谢谢,像魅力一样工作。【参考方案2】:

$('span:contains("11:00am"),span:contains("Jack")').parent("a").css("background-color", "Grey");
$('span:contains("11:00am"),span:contains("Tom")').parent("a").css("background-color", "Green");
<a style="background-color: rgb(255, 255, 255);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Tom</span>
</a>

<a style="background-color: rgb(255, 255, 255);">
  <div class="time">
    <span>11:00am</span>
  </div>
  <span class="name">Jack</span>
</a>

<head>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
</head>

【讨论】:

@Mohammad 谢谢你的回答也增加了我的知识:)

以上是关于选择元素有两个使用 jQuery 的特定子元素的主要内容,如果未能解决你的问题,请参考以下文章

jquery查找元素

如何使用jquery选择不是特定元素子元素的元素?

css 如何使用JQuery选择没有特定子元素的元素

使用 jQuery 获取不是具有特定 CSS 类的容器的子元素的元素的后代

使用 jQuery 定位元素的特定子元素

如何使用jQuery在某些特定div中选择具有相同名称的所有元素[重复]