查找没有具有特定 class 的直接子元素的元素

Find element that has no direct children with specific class

在包含 HTML 个元素的页面中,我试图找到 class .dmc 不包含具有特定 class 的直接子元素的父元素] .dynamic, 使用 JQuery.

我试过:

$('.dmc:not(:has(.dynamic))')

但是这会检查所有后代,而我只想检查第一级后代。

我认为有一个非常简单的答案,但我想不出来。任何帮助表示赞赏!

由于 :has 已经是 jQuery-specific,您可以使用无根的 >,jQuery 的 Sizzle 选择器引擎似乎支持:

$(".dmc:not(:has(> .dynamic))").addClass("green");
// --------------^

$(".dmc:not(:has(> .dynamic))").addClass("green");
.green {
  color: green;
  font-weight: bold;
}
<div class="dmc">1</div>
<div class="dmc">2
  <div class="dynamic">dynamic</div>
</div>
<div class="dmc">3</div>
<div class="dmc">4
  <div class="dynamic">dynamic</div>
</div>

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

但是我有点担心,可能会选择 filter:

$(".dmc").filter(function() {
  return $(this).children(".dynamic").length == 0;
}).addClass("green");

$(".dmc").filter(function() {
  return $(this).children(".dynamic").length == 0;
}).addClass("green");
.green {
  color: green;
  font-weight: bold;
}
<div class="dmc">1</div>
<div class="dmc">2
  <div class="dynamic">dynamic</div>
</div>
<div class="dmc">3</div>
<div class="dmc">4
  <div class="dynamic">dynamic</div>
</div>

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