jquery - 同一导航栏中的两个菜单

标签 jquery css twitter-bootstrap twitter-bootstrap-3

我希望在同一个导航栏行上有两个可折叠菜单。左侧菜单将显示站点的主菜单,而右侧菜单将显示“用户菜单”。

<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
   <div class="navbar-header">        
      <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#user-menu">
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
      </button>
      <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#main-menu">
         <span class="icon-bar"></span>
         <span class="icon-bar"></span>
         <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="#">My Site</a>
   </div>

   <span id="main-menu" class="navbar-collapse collapse">
      <ul class="nav navbar-nav">
         <li class="active"><a href="#">Home</a></li>
         <li><a href="about">About</a></li>
         <li><a href="members">Members</a></li>
         <li><a href="forum">Forum</a></li>
         <li><a href="mow">Register</a></li>
         <li class="dropdown">
            <a href="Products" class="dropdown-toggle" data-toggle="dropdown">Products <b class="caret"></b></a>
            <ul class="dropdown-menu">
               <li><a href="cars">Factions</a></li>
               <li><a href="software">Tanks</a></li>
               <li><a href="food">Infantry</a></li>
            </ul>
                </li>
              </ul>
            <form id="sys-login_form" target="passwordIframe" method="POST" action="blank.php" class="navbar-form navbar-right">
                 <span id="sys-login_status"></span>
                <div class="form-group">
                    <input type="text" placeholder="Username" class="form-control" name="username" id="sys-login-username" title="Username" data-active="0">
                </div>
                <div class="form-group">
                    <input type="password" placeholder="Password" class="form-control" name="password" id="sys-login-password" title="Password" data-active="0">
                </div>
                <input name="remember_login" id="sys-login-remember" type="checkbox" checked="checked" value="forever" title="Remember">
                <button type="button" class="btn btn-success" title="Login" name="login_btn" id="sys-login_btn" data-in_use="0">Go</button>
            </form>
            <iframe id="sys-passwordIframe" name="passwordIframe" style="display:none"></iframe>
      </span>

       <span id="user-menu" class="navbar-collapse collapse">
            <ul class="nav navbar-nav navbar-right">
                <li class="dropdown">
                    <a href="profile/fred" id="sys-username_box" class="dropdown-toggle" data-toggle="dropdown">Fred <b class="caret"></b></a>
                    <ul class="dropdown-menu">
                        <li><a href="account/settings">Settings</a></li>
                        <li><a data-in_use="0" href="account/logout">Logout</a></li>
                    </ul>
                </li>
                <li class="dropdown"><a href="about">Mail</a></li>
                <li><a href="about">Bookmarks</a></li>
            </ul>";
        </span>
  </div></div>

它在移动 View 中工作正常,即显示 2 个折叠菜单,但是在正常模式或全屏模式下,右侧的用户菜单被下推到主菜单下方的新行。

一个完整的例子可以在这里看到: http://bootply.com/79056

最佳答案

对于您的第一个导航栏,将pull-left 添加到class 属性,即

<ul class="nav navbar-nav pull-left">...</ul>

通常情况下,您不需要添加它,但因为您需要两个单独的可折叠菜单,所以需要告知第一个菜单向左浮动,这样第二个菜单就不会被强制向下。

这是一个 example .请注意,它假定如果您已登录,则只有然后 才会显示用户菜单。事实上,如果登录表单始终可见并且用户菜单始终可见,则 .container 类中指定的宽度将太窄。

关于jquery - 同一导航栏中的两个菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18631305/

相关文章:

css - 如果 Bootstrap CSS 文件托管在本地,字形会损坏

jquery - ASP.NET MVC 5 中的 Ajax(部分 View )不起作用 - 始终仅单独打开部分 View

javascript - 网页中的鼠标光标或键盘响应

javascript - 如何在javascript中打开一个图标

css - 如何将 jekyll-now 中的代码高亮更改为 Monokai 主题

javascript - HoverOver 上的 $http.get 填充 PopOver 文本

javascript - Jquery .text() 调用返回 null?

javascript - "new window"表单示例如何生效

html - 使用 flexbox 防止下一行占据上一行中最高元素的高度?

javascript - Onclick Bootstrap 按钮