Bootstrap 3-dropdown-Liste im navbar versteckt sich sofort nach Umschalten - show

Wie gezeigt, in diesem jsFiddle, ich habe eine nav-bar mit 2 dropdowns. Ein link in der ersten drop-down-feuert eine JS click-Ereignis, wo ich manuell die Karte der zweiten drop-down. Es funktioniert, außer dass nach gezeigt wird, die zweite drop-down automatisch und versteckt sich sofort. Ich habe eine Warnung zu geben, Sie Zeit, um den zweiten dropdown-bevor es versteckt.

http://jsfiddle.net/xNkS5/8/

Copy/paste von der JsFiddle-code:

    <div class="container">

        <!-- Brand and toggle get grouped for better mobile display -->
        <div class="navbar-header">
            <button type="button" class="navbar-toggle" data-toggle="collapse"
                data-target=".navbar-ex1-collapse">
                <span class="sr-only">Toggle navigation</span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
            </button>
            <a class="navbar-brand" href="http://toujoursplus.be/">Menu</a>
        </div>

        <!-- Collect the nav links, forms, and other content for toggling -->
        <div class="collapse navbar-collapse navbar-ex1-collapse">
            <ul class="nav navbar-nav">
                <li class="dropdown">
                   <a id="DropDown1" href="#" class="dropdown-toggle" data-toggle="dropdown">my drop down 1 <b class="caret"></b></a>
                   <ul class="dropdown-menu">
                        <li><a id="SwitchLink">Switch to drop down 2</a></li>
                   </ul>
                </li>
                <li class="dropdown">
                   <a id="DropDown2" href="#" class="dropdown-toggle" data-toggle="dropdown">my drop down 2 <b class="caret"></b></a>
                   <ul class="dropdown-menu">
                        <li><a href="#">Foo</a></li>
                        <li><a href="#">Bar</a></li>
                    </ul>
                </li>
            </ul>
        </div>
    </div>
</nav>

JavaScript

$(document).ready(function() {
        $("#SwitchLink").click(function(e) {
            e.preventDefault();//prevent the default anchor functionality
            $('#DropDown2').dropdown('toggle');
            alert("wait here... see DropDown2 deployed, then close this alert and see it's gone.");
        });
    });

Falls Sie sich Wundern, warum ich dies tun sollte: In unserer Anwendung die DropDown2 zeigt ein login-Formular. Manchmal, indem man auf den Menü-link in der DropDown1 sollte das login-Formular angezeigt.

jQuery-1.9.1 - Bootstrap 3.0.0
Passiert auf beiden Chrome und Firefox.

Ich bin ein Bootstrap-Neuling, und ich bin überzeugt, ich mache es falsch. Vielen Dank für Eure Hilfe.
John.

InformationsquelleAutor John Rizzo | 2013-09-16
Schreibe einen Kommentar