我一直试图检查div中是否存在类。但它总是产生一个长度为0.这是我的代码: -
<div id="accordion2" class="accordion" >
<div class="accordion-group">
<div class="accordion-heading"> <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseOne">
<div class="align-nav arrow-active">OSTOMY PRODUCTS</div></a>
</div>
<div id="collapseOne" class="accordion-body in collapse">
<div class="accordion-inner">
<ul>
<li><a href="#">Professional Resources</a></li>
<li><a href="#">One-piece Pouching</a></li>
</ul>
</div>
</div>
</div>
<div class="accordion-group">
<div class="accordion-heading"> <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseTwo">
<div class="align-nav arrow-inactive">LEARNING CENTER</div>
</a> </div>
<div id="collapseTwo" class="accordion-body collapse">
<div class="accordion-inner">
<ul>
<li><a href="#">Videos</a></li>
<li><a href="#">Before Your Surgery</a></li>
</ul>
</div>
</div>
</div>
<div class="accordion-group">
<div class="accordion-heading"> <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseThree">
<div class="align-nav">PROFESSIONAL RESOURCES </div>
</a> </div>
</div>
<div class="accordion-group">
<div class="accordion-heading"> <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseThree">
<div class="align-nav">PROFESSIONAL RESOURCES </div>
</a> </div>
</div>
</div>
对于前2个div $(this).find('accordion-body')。长度应为1.但它仍然显示0.我的Jquery COde如下: -
$('.accordion-heading').click(function() {
if($(this).find('accordion-body').exist()) {
alert('hi');
if($(this).find('.collapsed').length > 0) {
alert('hi');
//$(this).find('.accordion-toggle .align-nav').removeClass('arrow-active').addClass('arrow-inactive');
}
else {
alert('hi');
//$(this).find('.accordion-toggle .align-nav').removeClass('arrow-inactive').addClass('arrow-active');
}
}
});
我需要得到$(this).find('accordion-body')。length = 1; 请提供解决方案。
答案 0 :(得分:31)
你应该在find
中选择一个类选择器,因为你正在搜索类..而且因为手风琴体是父母后代使用parent()
试试这个
$(this).parent().find('.accordion-body').length == 1;
或者您可以使用hasClass()
答案 1 :(得分:1)
那将是'.accordion-body'
(这段时间至关重要 - 它是类选择器)。
同样.exist()
不是jQuery方法,但我假设你已经在某处定义了它。
答案 2 :(得分:0)
试试这个:
你应该找到兄弟姐妹而不是孩子,因为.accordion-body
不是.accordion-heading
的孩子,而是兄弟姐妹。
$('.accordion-heading').click(function() {
if($(this).siblings('.accordion-body').length > 0) {
alert('hi');
if($(this).siblings('.collapsed').length > 0) {
alert('hi');
//$(this).find('.accordion-toggle .align-nav').removeClass('arrow-active').addClass('arrow-inactive');
}
else {
alert('hi');
//$(this).find('.accordion-toggle .align-nav').removeClass('arrow-inactive').addClass('arrow-active');
}
}
});
您的代码中存在问题:
.exist()
不是检查任何元素的有效方法$(this).find()
这会发现孩子不是同级别的兄弟姐妹答案 3 :(得分:0)
你正在错误的环境中穿行。还可以尝试使用最新的jQuery和.on
方法
$('#accordion2').on('click','.accordion-heading', function() {
var accordionBodyLength = $(this).parent();
var $accordBody = $('.accordion-body');
alert(accordionBodyLength.find($accordBody).length);
});