Twitter Bootstrap点击多个下拉菜单 - jQuery帮助

时间:2013-07-29 08:57:34

标签: javascript jquery twitter-bootstrap drop-down-menu

我需要一点帮助来修改控制引导程序下拉列表的javascript。

我需要发生的是当你点击一个下拉列表时,它会显示出来。在顶级工作正常,但如果我想进入下拉列表中的下拉列表 例如:

<ul>
    <li>Dropdown 1
        <ul>
            <li>Dropdown 2
                <ul>
                    <li>List Item</li>
                    <li>List Item</li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

当我点击下拉列表1时,我可以看到名为下拉列表2的列表项,但是当我点击它时,它会再次关闭整个列表项。当你点击下拉列表2我需要它出现。 我找到了一个悬停方法来打开第二个嵌套下拉列表,但我需要它在点击时显示。

非常感谢帮助。这是一个小提琴:http://jsfiddle.net/raDUC/1/

1 个答案:

答案 0 :(得分:2)

试试这个:

HTML:

<div class="navbar navbar-fixed-top span2">
  <div class="navbar-inner"> <a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse"></a>  <a class="brand" href="#">Project Name</a>

    <div class="nav-collapse">
        <ul class="nav">
            <li class="dropdown">
                <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown 1</a>

                <ul class="dropdown-menu">
                    <li class="dropdown dropdown-nested"> <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown 2</a>

                        <ul class="dropdown-menu">
                            <li>Living and Nonliving things</li>
                        </ul>
                    </li>
                    <li> <a href="#">Another action</a>

                    </li>
                </ul>
            </li>
            <li> <a href="#">Link</a>

            </li>
            <li> <a href="#">Link</a>

            </li>
            <li> <a href="#">Link</a>

            </li>
            <li class="dropdown"> <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown</a>

                <ul class="dropdown-menu">
                    <li> <a href="#">Action</a>

                    </li>
                    <li> <a href="#">Another action</a>

                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <!-- /.nav-collapse -->
  </div>
  <!-- /.navbar-inner -->
</div>
<!-- /.navbar -->

JS:

$(function(){
  $('.dropdown-nested').click(function(event){
      event.stopPropagation();
      var dropdown = $(this).children('.dropdown-menu');
      dropdown.toggle();
  });
});

旁注...... 我建议在bootstrap的导航菜单中添加以下css:

ul.nav a {
    outline: none;
}

如果你点击一个主菜单项来关闭它,它会让丑陋的蓝色轮廓显示出来。