折叠引导选项卡 - 无法切换 .active 选项卡类



我使用(style) Bootstrap标签

我想关闭引导选项卡时,再次点击它。

它部分工作,我可以关闭相应的面板,但当我想切换选项卡的"活动"类时,脚本不工作。

我的JS代码:
$('[data-toggle=tab]').click(function(e){
    if($(this).parent().hasClass('active')){
        e.preventDefault();
        // toggle 'active' tab class (styling)
        $(this).parent().toggleClass('active');
        // toggle 'active' panel class (hide it)
        $($(this).attr("href")).toggleClass('active');
    }
})

所有代码(html, css, js)都可以在这里看到:https://jsfiddle.net/j9stkqf6/1/

注释:

$(this).parent().toggleClass('active');

面板是隐藏的

我还尝试了一步/一步调试模式所有工作正常,直到JS函数结束,所有重新出现(tab。活动类和面板)

你能帮我关闭面板和切换标签'活动'类时,再次点击标签。

谢谢!

终于修好了:

我必须添加'e.p stoppropagation()'到我的Javascript除了' . preventdefault ()'

'e.preventDefault()'在该事件(点击链接)上阻止Bootstrap的动作

'e.s stoppropagation()'避免Bootstrap (catch click on LI)的其他动作

cf。e.p preventdefault () vs e.p stoppropagation ()

$('[data-toggle=tab]').click(function(e){
    if($(this).parent().hasClass('active')){
    e.preventDefault();
    e.stopPropagation();
        $(this).parent().removeClass('active');
        $($(this).attr("href")).removeClass('active');
        $($(this).attr("href")).removeClass('in');
        $(this).attr("aria-expanded", false);
    }
})

您可以在这里看到我的工作示例:https://jsfiddle.net/j9stkqf6/10/

这是附加的演示,将帮助您

方法1

<link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    <script src="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div class="panel-group" id="accordion" role="tablist" aria-multiselectable="true">
    <div class="panel panel-info">
        <div class="panel-heading " role="tab" id="headingOne">
            <h4 class="panel-title">
                <a role="button" data-toggle="collapse" data-parent="#accordion" href="#per" aria-expanded="true" aria-controls="collapseOne">
                    <span class="glyphicon glyphicon-option-vertical"></span> <strong>Link 1</strong>
                </a>
            </h4>
        </div>
        <!--To make by defualt open a any panel put class "in" (without quotes)-->
        <div id="per" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingOne">
            <div class="panel-body">
                Link 1    Link 1    Link 1    Link 1    Link 1    Link 1
            </div>
        </div>
    </div>
    <div class="panel panel-info">
        <div class="panel-heading" role="tab" id="headingTwo">
            <h4 class="panel-title">
                <a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#family" aria-expanded="false" aria-controls="collapseTwo">
                    <span class="glyphicon glyphicon-option-vertical"></span> <strong>Link 2</strong>
                </a>
            </h4>
        </div>
        <div id="family" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingTwo">
            <div class="panel-body">
                Link 2  Link 2  Link 2  Link 2  Link 2  Link 2
            </div>
        </div>
    </div>
    <div class="panel panel-info">
        <div class="panel-heading" role="tab" id="headingThree">
            <h4 class="panel-title">
                <a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#social" aria-expanded="false" aria-controls="collapseThree">
                    <span class="glyphicon glyphicon-option-vertical"></span> <strong>Link 3</strong>
                </a>
            </h4>
        </div>
        <div id="social" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingThree">
            <div class="panel-body">
                Link 3  Link 3  Link 3  Link 3 Link 3   Link 3  Link 3
            </div>
        </div>
    </div>
</div>

方法2

要把所有的折叠在一起,你也可以使用类似的东西,你可以折叠所有的导航,其中有"in"类,因为打开的折叠有"in"类添加。您可以使用下面的脚本来捕获它们。

 $('#accordion .collapse').on('show.bs.collapse', function (e) {
        $('#accordion .in').collapse('hide');
    });

相关内容

  • 没有找到相关文章

最新更新