css - 在元素居中后 Bootstrap 垂直折叠导航栏菜单

标签 css twitter-bootstrap navbar

我的 Bootstrap 导航栏有问题。我最近找到了一种将导航栏中的元素居中的方法,但事实是,当菜单折叠时,这些元素保持水平对齐而不是垂直对齐。

这是我目前拥有的:

<div class="container-fluid">
<nav class="navbar navbar-inverse navbar-fixed-top fixfollow center">
    <div class="navbar-inner">
        <div class="container">

            <div class="navbar-header">
                <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".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 class="navbar-brand hidden-lg" href="/"><i class="fa fa-home fa-lg"></i></a>
            </div>
            <div class="collapse navbar-collapse">
                <ul class="nav navbar-nav">

                    <li>
                        <a class="navbar-brand visible-lg" href="/"><i class="fa fa-home fa-lg"></i></a>
                    </li>
                    <li>
                        <a href="/link">link</a>
                    </li>
                    <li>
                        <a href="/link">link</a>
                    </li>
                    <li>
                        <a href="/link">link</a>
                    </li>
                    <li>
                        <a href="/link">link</a>
                    </li>
                    <li>
                        <a href="/link">link</a>
                    </li>
                </ul>
            </div>
        </div>

    </div>
</nav>

和重要的CSS:

.center .nav,
 .center .nav > li
{
    float:none;
    display:inline-block;
    /*display:inline; /* ie7 fix */
    /*zoom:1; /* hasLayout ie7 trigger */
    vertical-align: top;
}


.center .navbar-inner {
    text-align:center;
}

.center .dropdown-menu {
    text-align: left;
}

有了这个,我的元素在导航栏中居中,但在折叠菜单中水平显示。我想获得一些帮助来更改它,以便恢复 Bootstrap 折叠菜单的经典行为(我的意思是垂直),而不会在菜单未折叠时更改居中的元素。

最佳答案

只需在媒体查询中应用您的规则:

@media (min-width: 767px) {
   YOUR RULES HERE
}

请参阅工作示例片段。

@media (min-width: 767px) {
  .center .nav,
  .center .nav > li {
    float: none;
    display: inline-block;
    vertical-align: top;
  }
  .center .navbar-inner {
    text-align: center;
  }
  .center .dropdown-menu {
    text-align: left;
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.1/css/font-awesome.min.css" rel="stylesheet" />
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet" />
<div class="container-fluid">
  <nav class="navbar navbar-inverse navbar-fixed-top fixfollow center">
    <div class="navbar-inner">
      <div class="container">

        <div class="navbar-header">
          <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".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 class="navbar-brand hidden-lg" href="/"><i class="fa fa-home fa-lg"></i></a>
        </div>
        <div class="collapse navbar-collapse">
          <ul class="nav navbar-nav">

            <li>
              <a class="navbar-brand visible-lg" href="/"><i class="fa fa-home fa-lg"></i></a>
            </li>
            <li>
              <a href="/link">link</a>
            </li>
            <li>
              <a href="/link">link</a>
            </li>
            <li>
              <a href="/link">link</a>
            </li>
            <li>
              <a href="/link">link</a>
            </li>
            <li>
              <a href="/link">link</a>
            </li>
          </ul>
        </div>
      </div>

    </div>
  </nav>

关于css - 在元素居中后 Bootstrap 垂直折叠导航栏菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37005714/

相关文章:

javascript - 在 div 中检测标题或段落或粗体/斜体

css - 为什么我的 bootstrap 导航栏在最小化时会被页面内容重叠?

css - 嵌套 float div 导致外部 div 不增长

html <ul> <li> 标签 - 内联显示

javascript - 如何将 ngMouseMove 事件计算与我的 div 对齐

html - 使用 bootstrap v3.3.2,我可以在 img 元素上放置一个字形图标吗?

angular - ng-select CSS 问题,bootstrap input-sm

css - 多级导航菜单悬停问题

html - 导航栏中的中心图像

javascript - 文档边栏中的元素不会自动激活