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

问题描述

这是我的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>

详细信息

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

问题

enter image description here

在这里您可以看到li之类的导航内容与后面的header内容一起显示。看起来不太好!

问题

我需要做什么-打开菜单后要清空导航栏后面的所有内容?因此它仅显示导航栏。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)