【发布时间】:2019-06-15 16:08:34
【问题描述】:
我的网站上有手风琴。它运行良好。如果一个手风琴打开并单击第二个,则它将关闭前一个手风琴。到目前为止没有问题。
我的问题是,如果点击手风琴,我必须关闭手风琴。我的意思是如果手风琴是打开的并且点击它,那么它应该是关闭的。
你能检查我的脚本我应该在哪里添加关闭脚本? 我试过了
$('.ac-pane.active .ac-title').click(function(){
getparent.find('.ac-pane').removeClass('active');
// $(this).next('.ac-content').slideUp();
$('.ac-pane .ac-content').css('display', 'none');
});
//Accordion
$(function() {
'use strict';
var selector = $('.ac-title');
$('.accordion-wrapper').each(function() {
if ($(this).find('.ac-pane').hasClass('active')) {
$('.ac-pane.active .ac-content').css('display', 'block');
}
});
selector.on('click', function(event) {
event.preventDefault();
// get the attr value
var attr = selector.attr('data-accordion');
var getparent = $(this).closest('.accordion-wrapper');
if ($(this).attr('data-accordion') == 'true') {
if ($(this).next('.ac-content').is(':visible')) {
return false;
} else {
getparent.find('.ac-content').slideUp();
$(this).next('.ac-content').slideDown();
getparent.find('.ac-pane').removeClass('active');
$(this).parent().addClass('active');
}
} else {
$(this).next('.ac-content').slideToggle();
$(this).parent().toggleClass('active');
}
});
});
.ac-pane {
margin-bottom: 15px;
color: #000;
}
.ac-pane:last-child {
margin-bottom: 0;
}
.ac-content {
display: none;
}
.ac-title {
/*border: 1px solid #000;*/
color: #000;
display: block;
padding: 12px;
}
.ac-title i {
float: right;
font-size: 20px;
}
.ac-title i:before {
content: "\f107";
}
.active .ac-title i:before {
content: "\f106";
}
.ac-content {
border: 1px solid #fff;
margin-top: -1px;
padding: 15px;
}
<link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.6.3/css/all.css">
<section>
<div class="container">
<div class="row">
<div class="col-sm-12">
<div class="heading">
<h2>Accordion Demo</h2>
</div>
<div class="accordion-wrapper">
<div class="ac-pane active">
<a href="#" class="ac-title" data-accordion="true">
<span>Hello World</span>
<i class="fa"></i>
</a>
<div class="ac-content">
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nihil ullam architecto earum reprehenderit dolore iusto labore sed, sunt, quasi soluta assumenda, a quam aspernatur repudiandae enim. Architecto, assumenda tempore vitae!
</div>
</div>
<div class="ac-pane">
<a href="#" class="ac-title" data-accordion="true">
<span>Hello World</span>
<i class="fa"></i>
</a>
<div class="ac-content">
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nihil ullam architecto earum reprehenderit dolore iusto labore sed, sunt, quasi soluta assumenda, a quam aspernatur repudiandae enim. Architecto, assumenda tempore vitae!
</div>
</div>
<div class="ac-pane">
<a href="#" class="ac-title" data-accordion="true">
<span>Hello World</span>
<i class="fa"></i>
</a>
<div class="ac-content">
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nihil ullam architecto earum reprehenderit dolore iusto labore sed, sunt, quasi soluta assumenda, a quam aspernatur repudiandae enim. Architecto, assumenda tempore vitae!
</div>
</div>
<div class="ac-pane">
<a href="#" class="ac-title" data-accordion="true">
<span>Hello World</span>
<i class="fa"></i>
</a>
<div class="ac-content">
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nihil ullam architecto earum reprehenderit dolore iusto labore sed, sunt, quasi soluta assumenda, a quam aspernatur repudiandae enim. Architecto, assumenda tempore vitae!
</div>
</div>
</div>
</div>
</div>
</div>
</section>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.0/jquery.min.js"></script>
【问题讨论】:
-
@AswinKumar,感谢您的链接,但我没有使用引导手风琴。
-
你必须接受一个有效的答案
标签: javascript jquery html css