删除导航和 header 之间的小间隙

Remove small gap between nav and header

我的导航栏(位于页面顶部)和header(在导航栏下方,有大图像和上面的文字 ),它们之间有一个我想删除的非常小的间隙。我访问过许多关于类似问题的帖子,并尝试了他们的解决方案,但似乎对我不起作用,包括:display: block; margin: 0; e.t.c.

我想这与我在 header 的内容或导航的内容上应用的样式有关。

body {
  margin: 0px;
  padding: 0px;
  background-color: #f2f2f2;
}
html {
  margin: 0px;
  padding: 0px;
}
#logo {
  height: 50px;
  width: auto;
  float: left;
}
nav ul {
  list-style-type: none;
  overflow: hidden;
  margin: 0;
  padding: 0;
  background-color: #1a1a1a;
  text-align: center;
  border: 1px solid #e7e7e7;
  display: inline-block;
  width: 100%;
}
nav li {
  display: inline-block;
}
nav a {
  display: inline-block;
  padding: 16px 15px;
  text-decoration: none;
  font-family: arial;
  font-weight: bold;
  color: white;
}
nav a:hover {
  background-color: orange;
  color: white;
}
nav {
  margin-bottom: 0;
}
header {
  margin-top: 0;
  margin-bottom: 10px;
  width: 100%;
  font-family: arial;
  font-size: 18px;
  color: orange;
}
h1 {
  position: absolute;
  top: 150px;
  width: 100%;
  z-index: 1;
  text-align: center;
}
#bannerImage {
  width: 100%;
  height: auto;
  position: relative;
  z-index: 0;
}
<nav>
  <ul>
 <img id="logo" src="https://67.media.tumblr.com/f607af5bc60d1b2837add83c70a2aa45/tumblr_inline_mrwv19q8fE1qz4rgp.gif"/>
 <li><a href="Game1.html" id="myBtn" onclick="disableLink()" >Game 1</a></li><li><a href="">Game 2</a></li><li><a href="">Game 3</a></li>
  </ul>
</nav>
 
<header>
  <img id="bannerImage" src="http://static2.hypable.com/wp-content/uploads/2014/09/Hogwarts-lake.png"/>
  <h1>Games</h1>
</header>

问题是由您的 ul overflow:hidden 引起的,所以只需将其删除即可。

添加了box-sizing:border-box以避免水平滚动条

更新

我注意到您有一个 img 作为 ul 的 child,这使得 HTML.

无效

所以我调整了您的代码以使其有效。

*,
*::before,
*::after {
  box-sizing: border-box
}
body,
html {
  margin: 0;
  padding: 0;
  background-color: #f2f2f2;
}
#logo {
  height: 50px;
  width: auto;
  display: inline-block;
  vertical-align:top
}
nav {
  margin-bottom: 0;
  background-color: #1a1a1a;
  border: 1px solid #e7e7e7;
}
nav ul {
  list-style-type: none;
  width: calc(100% - 60px);
  margin:0;
  padding: 0;
  text-align: center;
  display: inline-block;
  vertical-align: top;
}
nav li {
  display: inline-block;
}
nav a {
  display: inline-block;
  padding: 16px 15px;
  text-decoration: none;
  font-family: arial;
  font-weight: bold;
  color: white;
}
nav a:hover {
  background-color: orange;
  color: white;
}
header {
  margin-top: 0;
  margin-bottom: 10px;
  width: 100%;
  font-family: arial;
  font-size: 18px;
  color: orange;
}
h1 {
  position: absolute;
  top: 150px;
  width: 100%;
  z-index: 1;
  text-align: center;
}
#bannerImage {
  width: 100%;
  height: auto;
  position: relative;
  z-index: 0;
}
<nav>
  <img id="logo" src="https://67.media.tumblr.com/f607af5bc60d1b2837add83c70a2aa45/tumblr_inline_mrwv19q8fE1qz4rgp.gif" />
  <ul>
    <li><a href="Game1.html" id="myBtn" onclick="disableLink()">Game 1</a>
    </li>
    <li><a href="">Game 2</a>
    </li>
    <li><a href="">Game 3</a>
    </li>
  </ul>
</nav>

<header>
  <img id="bannerImage" src="http://static2.hypable.com/wp-content/uploads/2014/09/Hogwarts-lake.png" />
  <h1>Games</h1>
</header>

尝试设置导航的高度:

nav {
  height: 50px;
}

尝试了一下,即使没有将边距设置为 0 也能正常工作。

只需定义nav

的高度

body {
  margin: 0px;
  padding: 0px;
  background-color: #f2f2f2;
}
html {
  margin: 0px;
  padding: 0px;
}
#logo {
  height: 50px;
  width: auto;
  float: left;
}
nav ul {
  list-style-type: none;
  overflow: hidden!important;
  margin: 0;
  padding: 0;
  background-color: #1a1a1a;
  text-align: center;
  border: 1px solid #e7e7e7;
  display: inline-block;
  width: 100%;
}
nav li {
  display: inline-block;
}
nav a {
  display: inline-block;
  padding: 16px 15px;
  text-decoration: none;
  font-family: arial;
  font-weight: bold;
  color: white;
}
nav a:hover {
  background-color: orange;
  color: white;
}
nav {
  margin-bottom: 0;
  height: 51px;
}
header {
  margin-top: 0;
  margin-bottom: 10px;
  width: 100%;
  font-family: arial;
  font-size: 18px;
  color: orange;
}
h1 {
  position: absolute;
  top: 150px;
  width: 100%;
  z-index: 1;
  text-align: center;
}
#bannerImage {
  width: 100%;
  height: auto;
  position: relative;
  z-index: 0;
}
<nav>
  <ul>
 <img id="logo" src="https://67.media.tumblr.com/f607af5bc60d1b2837add83c70a2aa45/tumblr_inline_mrwv19q8fE1qz4rgp.gif"/>
 <li><a href="Game1.html" id="myBtn" onclick="disableLink()" >Game 1</a></li><li><a href="">Game 2</a></li><li><a href="">Game 3</a></li>
  </ul>
</nav>
 
<header>
  <img id="bannerImage" src="http://static2.hypable.com/wp-content/uploads/2014/09/Hogwarts-lake.png"/>
  <h1>Games</h1>
</header>