2

内部にドロップダウン メニューがあるナビゲーション バーを作成しようとしましたが、これでは内部にドロップダウン メニューがありません。しかし、それをクリックすると、メニューが閉じます。クリックすると消えるこの機能をブロックしたくありません。それが原因で機能しないと思うからです。https://github.com/twitter/bootstrap/pull/3383で stopPropagation について見ましたが、これをどこで宣言できるかわかりません。また、公式ではありません。

編集 : モバイルまたはタブレットを使用している場合、リンクに触れるとメニューが閉じるため、 li class="dropdown-submenu" は使用できません。

私のコードがあります:

<div class="bs-docs-example">
    <div class="navbar">
      <div class="navbar-inner">
        <div class="container">
          <a class="btn btn-navbar" data-toggle="collapse" data-target=".navbar-responsive-collapse">
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
          </a>
          <a class="brand" href="/app/alink">Title</a>
          <div class="nav-collapse collapse navbar-responsive-collapse">
                <ul class="nav">
                    <li class="dropdown">
                        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Article A<b class="caret"></b></a>
                        <ul class="dropdown-menu">
                            <li><a href="/app/alink">Title Article 1-A</a></li>
                            <li><a href="/app/alink">Title Article 2-A</a></li>
                        </ul>
                    </li>
                    <li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown">More ...<b class="caret"></b></a>
                        <ul class="dropdown-menu">
                            <li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown">Article B<b class="caret"></b></a>
                                <ul class="dropdown-menu">
                                    <li><a href="/app/alink">article 1-B</a></li>
                                </ul>
                            </li>
                            <li><a href="#" class="dropdown-toggle" data-toggle="dropdown">Article C<b class="caret"></b></a></li>
                            <li><a href="#" class="dropdown-toggle" data-toggle="dropdown">Article D<b class="caret"></b></a></li>
                        </ul>
                    </li> 
                </ul>
            </div>
        </div>
    </div>
</div>


4

3 に答える 3

2

別の解決策を見つけました。コードの後に​​追加しました:

<script type="text/javascript"> 
$('.dropdown-menu').click(function(event){
    event.stopPropagation();
});
</script>

ドロップダウンはこのソリューションでは機能しないため、「ドロップダウンサブメニュー」を使用して修正しました(@Schmalzyに感謝します)。リンクに触れると、サブメニューが開きます。上記のコードがないと、サブメニューはタブレットで正常に動作しません。

于 2013-07-31T12:36:11.417 に答える
0

このリンクでわかるように、問題は Bootstrap V2.3.2 にあります http://getbootstrap.com/2.3.2/examples/carousel.html

ブートストラップをバージョン 3 にアップグレードするか、このスタイルを使用して問題を解決できます

/*Fix navbar dropdown collapsed on mobile devices*/
.dropdown-backdrop {
    position: static;
}

http://yogarelax.harpoonmysite.com/に感謝します。

于 2015-02-21T02:40:16.680 に答える
0

bootstrap3 のレスポンシブ ドロップダウン メニューを使用できます。

<header class="navbar navbar-inverse navbar-fixed-top bs-docs-nav" role="banner">
  <div class="container">
    <div class="navbar-header">
      <button class="navbar-toggle collapsed" type="button" data-toggle="collapse" data-target=".bs-navbar-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 href="./" class="navbar-brand">Bootstrap</a>
    </div>
    <nav class="navbar-collapse bs-navbar-collapse collapse" role="navigation" style="height: 1px;">
      <ul class="nav navbar-nav">
        <li>
          <a href="./getting-started">Getting started</a>
        </li>
        <li>
          <a href="./css">CSS</a>
        </li>
        <li>
          <a href="./components">Components</a>
        </li>
        <li>
          <a href="./javascript">JavaScript</a>
        </li>
        <li>
          <a href="./customize">Customize</a>
        </li>
      </ul>
    </nav>
  </div>
</header>
于 2013-10-06T07:08:08.367 に答える