我的代码可以工作到: 当我单击折叠或展开全部时,它起作用并将按钮的文本从全部折叠更改为全部展开。唯一的问题是:当我通过单击标题打开或关闭所有面板时,它也应该更改按钮的文本。
我希望我已经解决了足够多的问题。
我没有在这个例子中包含 Jquery 和 bootstrap 外部文件。但您可以在以下链接中找到示例。
Jquery
$('.expand-all').click(function(){
var $this = $(this);
$this.toggleClass('collapse-all');
if($this.hasClass('collapse-all')){
$this.text(' Expand All');
$('.panel-collapse.in')
.collapse('hide');
}
else {
$this.text('Collapse All');
$('.panel-collapse:not(".in")')
.collapse('show');
}
});
HTML
<div class="container">
<!-- <a href="#" class="btn btn-default openall">open all</a> <a href="#" class="btn btn-default closeall">close all</a>--><a href="#" class="btn btn-default expand-all">Collapse All</a>
<hr>
<div class="panel-group" id="accordion">
<div class="panel panel-default">
<div class="panel-heading" data-toggle="collapse" data-parent="#accordion1" href="#collapseOne">
<h4 class="panel-title">
<a class="" >
Collapsible Group Item #1
</a>
</h4>
</div>
<div id="collapseOne" class="panel-collapse collapse in">
<div class="panel-body">
ONe
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading">
<h4 class="panel-title">
<a class="" data-toggle="collapse" data-parent="#accordion1" href="#collapseTwo">
Collapsible Group Item #2
</a>
</h4>
</div>
<div id="collapseTwo" class="panel-collapse collapse in">
<div class="panel-body">
Two Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. 3 wolf moon officia aute, non cupidatat skateboard dolor brunch. Food truck quinoa nesciunt laborum eiusmod. Brunch 3 wolf moon tempor, sunt aliqua put a bird on it squid single-origin coffee nulla assumenda shoreditch et. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident. Ad vegan excepteur butcher vice lomo. Leggings occaecat craft beer farm-to-table, raw denim aesthetic synth nesciunt you probably haven't heard of them accusamus labore sustainable VHS.
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading">
<h4 class="panel-title">
<a class="" data-toggle="collapse" data-parent="#accordion1" href="#collapseThree">
Collapsible Group Item #3
</a>
</h4>
</div>
<div id="collapseThree" class="panel-collapse collapse in">
<div class="panel-body">
Three Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. 3 wolf moon officia aute, non cupidatat skateboard dolor brunch. Food truck quinoa nesciunt laborum eiusmod. Brunch 3 wolf moon tempor, sunt aliqua put a bird on it squid single-origin coffee nulla assumenda shoreditch et. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident. Ad vegan excepteur butcher vice lomo. Leggings occaecat craft beer farm-to-table, raw denim aesthetic synth nesciunt you probably haven't heard of them accusamus labore sustainable VHS.
</div>
</div>
</div>
</div>
</div>
最佳答案
这会解决你的问题
$(".panel-heading a").click(function(){
setTimeout(function(){
if($(".collapsed").length == $(".panel-heading").length){
$(".btn-default").text(' Expand All');
if(!$('.expand-all').hasClass('collapse-all')){
$('.expand-all').addClass('collapse-all')
}
}else{
$(".btn-default").text('Collapse All');
}
},100)
})
这里是 fiddle http://jsfiddle.net/26hu7o5y/4/
关于javascript - 折叠并展开所有 bootstrap 3 Accordion ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32371228/