html - 如何消除 Bootstrap 导航栏和下拉项之间的差距

标签 html css twitter-bootstrap

如果我的导航栏和下拉项之间存在这个透明的小间隙,我很难找到来源。它正在杀死我。谁能帮我找到并移除它?

enter image description here

我的 HTML

 <!-- Static navbar -->
<nav id="custom-bootstrap-menu" class="navbar navbar-default navbar-static-top">
  <div class="container">
    <div class="navbar-header">
      <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
        <span class="sr-only">Toggle navigation</span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
          </button>
          <div id="navlogo">            
            <a class="navbar-brand" href="#">CHEEZ-IT!</a>
          </div>
        </div>
        <div id="navbar" class="navbar-collapse collapse">
          <ul class="nav navbar-nav">
            <li><a href="#">Home</a></li>
            <li class="dropdown">
              <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">About Us <span class="caret"></span></a>
              <ul class="dropdown-menu">
                <li><a href="#">Who are Cheez-it's</a></li>
                <li><a href="#">Credentials</a></li>
              </ul>
            </li>
            <li><a href="#contact">Our Services</a></li>
            <li class="dropdown">
              <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">Industries <span class="caret"></span></a>
              <ul class="dropdown-menu">
                <li><a href="#">Cheeze-it Solar</a></li>
                <li><a href="#">Cheeze-it Infrastructure</a></li>
                <li><a href="#">Cheeze-it Harvest</a></li>                
              </ul>
            </li>

            <li><a href="#contact">Partners</a></li>
            <li><a href="#contact">Contact</a></li>
          </ul>
        </div><!--/.nav-collapse -->
      </div>
    </nav>

这是我的 CSS,但我不认为这是造成它的原因。

#custom-bootstrap-menu.navbar-default .navbar-brand {
    color: #fbb216;
}
#custom-bootstrap-menu.navbar-default {
    font-size: 14px;
    background-color: rgba(13, 65, 103, 1);
    border-width: 0px;
    border-radius: 0px;
}
#custom-bootstrap-menu.navbar-default .navbar-nav>li>a {
    color: rgba(255, 255, 255, 1);
    background-color: rgba(13, 65, 103, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-nav>li>a:hover,
#custom-bootstrap-menu.navbar-default .navbar-nav>li>a:focus {
    color: rgba(13, 65, 103, 1);
    background-color: rgba(255, 255, 255, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-nav>.active>a,
#custom-bootstrap-menu.navbar-default .navbar-nav>.active>a:hover,
#custom-bootstrap-menu.navbar-default .navbar-nav>.active>a:focus {
    color: rgba(13, 65, 103, 1);
    background-color: rgba(255, 255, 255, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-toggle {
    border-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle:hover,
#custom-bootstrap-menu.navbar-default .navbar-toggle:focus {
background-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle .icon-bar {
background-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle:hover .icon-bar,
#custom-bootstrap-menu.navbar-default .navbar-toggle:focus .icon-bar {
background-color: #ffffff;
}

感谢任何帮助!谢谢

最佳答案

此规则 (border-width: 0px;) 导致了间隙。

您可以添加与您的 navbar 颜色相同的底部边框(或者您可以将 dropdown-menu 类的边距减少 1px,但它看起来确实很尴尬因为 dropdown-menudropdown 触发器不完全一致。

带边距的替代方法

@media (min-width: 768px) {
    #custom-bootstrap-menu.navbar-default .dropdown-menu {
        border: none;
        margin-top: -1px;
    }
}

底部边框方法:参见工作示例

html {
  background-color: red;
}
#custom-bootstrap-menu.navbar-default .navbar-brand {
  color: #fbb216;
}
#custom-bootstrap-menu.navbar-default {
  font-size: 14px;
  background-color: rgba(13, 65, 103, 1);
  border: none;
  border-bottom: 1px solid rgba(13, 65, 103, 1);
  border-radius: 0px;
}
#custom-bootstrap-menu.navbar-default .navbar-nav > li > a {
  color: rgba(255, 255, 255, 1);
  background-color: rgba(13, 65, 103, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-nav > li > a:hover,
#custom-bootstrap-menu.navbar-default .navbar-nav > li > a:focus {
  color: rgba(13, 65, 103, 1);
  background-color: rgba(255, 255, 255, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-nav > .active > a,
#custom-bootstrap-menu.navbar-default .navbar-nav>.active>a:hover,
#custom-bootstrap-menu.navbar-default .navbar-nav>.active>a:focus {
  color: rgba(13, 65, 103, 1);
  background-color: rgba(255, 255, 255, 1);
}
#custom-bootstrap-menu.navbar-default .navbar-toggle {
  border-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle:hover,
#custom-bootstrap-menu.navbar-default .navbar-toggle:focus {
  background-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle .icon-bar {
  background-color: #ffffff;
}
#custom-bootstrap-menu.navbar-default .navbar-toggle:hover .icon-bar,
#custom-bootstrap-menu.navbar-default .navbar-toggle:focus .icon-bar {
  background-color: #ffffff;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<nav id="custom-bootstrap-menu" class="navbar navbar-default navbar-static-top">
  <div class="container">
    <div class="navbar-header">
      <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar"> <span class="sr-only">Toggle navigation</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>

      </button>
      <div id="navlogo"> <a class="navbar-brand" href="#">CHEEZ-IT!</a>

      </div>
    </div>
    <div id="navbar" class="navbar-collapse collapse">
      <ul class="nav navbar-nav">
        <li><a href="#">Home</a>

        </li>
        <li class="dropdown"> <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">About Us <span class="caret"></span></a>

          <ul class="dropdown-menu">
            <li><a href="#">Who are Cheez-it's</a>

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

            </li>
          </ul>
        </li>
        <li><a href="#contact">Our Services</a>

        </li>
        <li class="dropdown"> <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">Industries <span class="caret"></span></a>

          <ul class="dropdown-menu">
            <li><a href="#">Cheeze-it Solar</a>

            </li>
            <li><a href="#">Cheeze-it Infrastructure</a>

            </li>
            <li><a href="#">Cheeze-it Harvest</a>

            </li>
          </ul>
        </li>
        <li><a href="#contact">Partners</a>

        </li>
        <li><a href="#contact">Contact</a>

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

关于html - 如何消除 Bootstrap 导航栏和下拉项之间的差距,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33112256/

相关文章:

php - php 文件中的 html 输入类型

css - 如何使跨度将可用空间拉伸(stretch)到其他跨度?

jquery - 如何使用jquery使点击 anchor 标记后在同一页面弹出表单

html - Bootstrap 轮播中的图像未填充轮播区域

jquery - Bootstrap X-可编辑、文本区域的清除按钮

javascript - 如何获取用户在 SumoSelect 中选择的值?

javascript - 如果只有一个图像,则停止循环播放幻灯片 + 加载幻灯片时停止第一张图像的淡入淡出

css - 行高差距 - 内容不垂直居中

css - 需要在我的桌面上测试网站,就像在电脑上测试 iPhone 4

html - CSS 中的顶部和底部边框不会在 <div> 标记内垂直对齐文本