【发布时间】:2016-02-21 14:32:55
【问题描述】:
我想查找与选择器匹配的所有元素,但如果它已包含在匹配元素中,则不查找。
$('#container').find('.child').not('.child .child');
请注意,.child 元素不是必需的直接后代。
为什么这不起作用?
我想选择所有将出现在$('#container').find('.child') 中的元素,但排除/filter() 任何会出现在$('#container').find('.child .child') 中的元素,因为它的祖先之一是.child
var children = $('#container').find('.child').filter(function (i, el) {
return !$(el).closest('.child').length;
});
由于某种原因,这也不起作用JSFIDDLE
sn-p 改编自 @RonenCypis 答案
var selector = ' .child ';
var children = $('#container').find(selector).filter(function(i, el) {
return !$(el).closest(selector).length;
});
children.css('background-color', 'blue');
#container div {
float: left;
display: inline-block;
width: 50px;
height: 50px;
color: #fff;
margin: 10px;
background-color: red;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="container">
<div class="child">one
<div class="child">one one</div>
</div>
<div class="child">two
<div class="child">two one</div>
</div>
<div class="child">three</div>
<div class="child">four
<div class="child">four one</div>
</div>
</div>
【问题讨论】:
标签: javascript jquery