Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie kann verhindert werden, dass sich das Bootstrap-Dropdown-Menü schließt, wenn man darauf klickt?

Barbara Streisand
Freigeben: 2024-10-25 12:48:02
Original
623 Leute haben es durchsucht

How to Prevent Bootstrap Dropdown from Closing When Clicking Inside?

Schließen beim Klicken im Dropdown-Menü verhindern

In Twitter Bootstrap wird das Dropdown-Menü beim Klicken geschlossen (sogar beim Klicken im Menü). Um dies zu vermeiden, können Sie einen Click-Event-Handler an das Dropdown-Menü anhängen und die berühmte event.stopPropagation() hinzufügen.

<code class="html"><ul class="nav navbar-nav">
  <li class="dropdown mega-dropdown">
    <a href="javascript:;" class="dropdown-toggle" data-toggle="dropdown">
      <i class="fa fa-list-alt"></i> Menu item 1
      <span class="fa fa-chevron-down pull-right"></span>
    </a>
    <ul class="dropdown-menu mega-dropdown-menu">
      <li>
        <div id="carousel" class="carousel slide" data-ride="carousel">
          <ol class="carousel-indicators">
            <li data-slide-to="0" data-target="#carousel"></li>
            <li class="active" data-slide-to="1" data-target="#carousel"></li>
          </ol>
          <div class="carousel-inner">
            <div class="item">
              <img alt="" class="img-rounded" src="img1.jpg">
            </div>
            <div class="item active">
              <img alt="" class="img-rounded" src="img2.jpg">
            </div>
          </div>
          <a data-slide="prev" role="button" href="#carousel" class="left carousel-control">
            <span class="glyphicon glyphicon-chevron-left"></span>
          </a>
          <a data-slide="next" role="button" href="#carousel" class="right carousel-control">
            <span class="glyphicon glyphicon-chevron-right"></span>
          </a>
        </div>
      </li>
    </ul>
  </li>
</ul></code>
Nach dem Login kopieren

Diese Methode scheint einfach und sehr verbreitet zu sein, aber da die Event-Handler von Karussell-Steuerelementen (und Karussell-Indikatoren) an das Dokumentobjekt delegiert werden, ist sie für diese Elemente (vorherige/nächste Steuerelemente) nicht geeignet usw. ) werden „ignoriert“.

<code class="js">$('ul.dropdown-menu.mega-dropdown-menu').on('click', function(event){
    // 不会向document 节点传播事件
    // 所以委托的事件不会被触发
    event.stopPropagation();
});</code>
Nach dem Login kopieren

Das Verlassen auf die Dropdown-Ereignisse zum Ausblenden/Ausblenden von Twitter Bootstrap ist aus folgenden Gründen keine Lösung:

  • Die von diesen beiden Ereignishandlern bereitgestellten Ereignisobjekte verweisen nicht auf die angeklickten Ereignisse Element.
  • Es gibt keine Kontrolle über den Inhalt des Dropdown-Menüs, daher kann die Flag-Klasse oder das Flag-Attribut nicht hinzugefügt werden.

Das Folgende ist eine Fiddle-Demo mit normalem Verhalten und eine Fiddle-Demo mit hinzugefügtem event.stopPropagation().

Update

Danke Roman für die Antwort. Ich habe auch eine andere Antwort gefunden:

<code class="js">$(document).on('click', 'someyourContainer .dropdown-menu', function (e) {
  e.stopPropagation();
});</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann verhindert werden, dass sich das Bootstrap-Dropdown-Menü schließt, wenn man darauf klickt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!