javascript - 折叠并展开所有 bootstrap 3 Accordion

标签 javascript jquery html css twitter-bootstrap

我的代码可以工作到: 当我单击折叠或展开全部时,它起作用并将按钮的文本从全部折叠更改为全部展开。唯一的问题是:当我通过单击标题打开或关闭所有面板时,它也应该更改按钮的文本。

我希望我已经解决了足够多的问题。

我没有在这个例子中包含 Jquery 和 bootstrap 外部文件。但您可以在以下链接中找到示例。

jsfiddle example here.

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/

相关文章:

javascript - undefined variable javascript - 灯箱

用于查找数组中不在另一个数组中的元素的 Javascript 算法

html - “A” 标签包装 “IMG” 似乎大小不正确。 (32 * 32px 显示为 38 * 21px)

javascript - 无论如何从 form.submit() 返回 JSON

Javascript 数组的总和和平均值

javascript - 在显示主要内容之前向所有页面添加预加载器页面

jquery - 折叠表格而不重新布局

javascript - 输入字段的 PHP 计数器

html - X-UA-Compatible 元标记应该出现在字符集标记之前还是之后

javascript - 不能在 img 标签内使用 base64 图像吗?