0
我使用相同的模式嵌套控件并基于传递的控件div ID,我想选择除item之外的所有项目(“。inner”)内部控制。获取子元素不是具有某个CSS类的容器的子元素
<div id="Main" class="outer">
<div class="item">
<div class="inner">inner1</div>
<div id="Maininner" class="outer">
<div class="item">
<div class="inner">sub inner1</div>
</div>
</div>
</div>
</div>
<script type="text/javascript">
function GetItem(id) {
var item = $($(id).find(".item:first"));
item.find(".inner:not(.outer .outer .inner)").each(function() {
alert(id + ": " + $(this).html());
});
}
if (typeof $ != "undefined") {
$(function() {
GetItem("#Main"); //expected output "inner1" , **working**
GetItem("#Maininner"); //expected output "sub inner1" **not working**
});
};
</script>
我想编写通用函数来处理这种情况。我尝试使用“:不是”,但它只适用于某些场景。 任何更好的方式来编写代码,这两种方案的工作? 注意:我无法更改HTML结构。
如果“inner”div不是“item”的直接子元素,则此逻辑不起作用。 – user1760384
检查下面的小提琴 http://jsfiddle.net/6Z84w/2/ –