查找没有具有特定 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>
在包含 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>