CSS 响应式导航栏在打开汉堡包时删除后面的内容

CSS responsive nav bar remove content behind when opened haburger

这是我的 HTML 和 CSS

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 20px;
}

.row {
  max-width: 1140px;
  margin: 0 auto;
}

/* ------------ NAVIGATION ------------  */

.main-nav {
  float: right;
  list-style: none;
  margin-top: 40px;
}

.main-nav li {
  display: inline-block;
  margin-left: 40px;
}

.main-nav li a {
  text-decoration: none;
  text-transform: uppercase;
  font-size: 90%;
}

.main-nav ul li a {
  position: relative;
  z-index: 1;
  padding: 15px;
}


.main-nav label #btn,
.main-nav label #cancel {
  font-size: 180%;
  cursor: pointer;
  float: right;
  margin-right: 40px;
  display: none;
}

.main-nav #check {
  display: none;
}

/* ------------ HEADER ------------  */

header {
  height: 100vh;
}

.landing {
  position: absolute;
  width: 1140px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

.landing p {
  margin-bottom: 15px;
}

h1 {
  margin-top: 0;
  margin-bottom: 20px;
  font-size: 280%;
  font-weight: 300;
  word-spacing: 3px;
  letter-spacing: 1px;
}



/* ------------ BUTTONS ------------  */

.btn:link,
.btn:visited {
  display: inline-block;
  padding: 10px 30px;
  text-decoration: none;
  background-color: #0097e6;
  border-radius: 200px;
  color: #fff;
}

/* ------------ MEDIA QUERIES ------------  */
@media (max-width: 860px) {

  .main-nav label #btn {
    display: block;
  }
  .main-nav ul {
    position: fixed;
    width: 100%;
    height: 100vh;
    top: 80px;
    left: -100%;
    text-align: center;
    transition: all .5s;
  }
  .main-nav ul li{
    display: block;
    margin: 50px 0;
    line-height: 30px;
  }
  .main-nav #check:checked ~ ul {
    left: 0;
  }
  .main-nav #check:checked ~ label #btn {
    display: none;
  }
  .main-nav #check:checked ~ label #cancel {
    display: block;
  }
}
<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
    <link rel="stylesheet" href="style.css">
    <script src="https://use.fontawesome.com/releases/v5.0.8/js/all.js"></script>
  </head>
  <body>


    <header>
      <div class="row">
        <div class="main-nav">
          <nav>
            <input type="checkbox" id="check">
            <label for="check">
              <i class="fas fa-bars" id="btn"></i>
              <i class="fas fa-times" id="cancel"></i>
            </label>
            <ul>
              <li><a href="#">Home</a></li>
              <li><a href="#">About me</a></li>
              <li><a href="#">Projects</a></li>
              <li><a href="#">Contact me</a></li>
            </ul>
          </nav>
        </div>
      </div>
      <div class="landing">
        <h1>One</h1>
        <p>Two</p>
      </div>
    </header>

  </body>
</html>

详情

我刚刚根据设备宽度创建了响应式导航。

问题

这里可以看到li等导航内容和后面的header内容一起显示。不好看!

问题

我需要做什么 - 打开菜单后清除导航栏后面的所有内容?所以它只显示导航栏。

虽然还有许多其他方面需要改进,但我怀疑您想要的一个简单解决方案是将这些样式添加到您的 ul:

ul {
    position: relative; /* allows for z-index usage */
    z-index: 2; /* value higher than that of the content you want 'behind' */
    background-color: #fff; /* non-transparent background */
}

您可以使用 JavaScript 将显示更改为您想要隐藏的 div 中的非显示,或者将响应颜色的 background-color 设为白色,以便隐藏任何内容就在后面。