在移动设备中单击任何 link 时,汉堡菜单不会折叠

Hamburger menu doesn't collapse on click any link in mobile

我正在建立一个网站并 运行 解决这个问题。 我有一个基本的导航栏,当在移动设备上查看时,它看起来像一个汉堡菜单。菜单工作正常。我使用纯 HTML-CSS 代码来制作这个导航栏。问题是当我单击菜单上的任何 link 以导航到页面的不同部分时,导航栏没有关闭。

HTML:

<header class="navbar-fixed-top">
    <div class="container">
        <nav>
          <input type="checkbox" id="nav" class="hidden">
          <label for="nav" class="nav-btn">
            <i></i>
            <i></i>
            <i></i>
          </label>

          <div class="nav-wrapper">
            <ul>
                <li><a href="#home">HOME</a></li>
                <li><a href="#mint">MINT</a></li>
                <li><a href="#community">COMMUNITY</a></li>
                <li><a href="#projects">PROJECTS</a></li>
                <li><a href="#faq">FAQ</a></li>
              </ul>
          </div>
        </nav>
    </div>
</header>

CSS

header {
text-align: right;
-webkit-transition: all .5s;
transition: all .5s;
height: 65px;}
nav {
  
padding: 8px;

}
nav ul {

margin-bottom: 0;
float:right;
-webkit-transition: all .5s;
transition: all .5s; 
}

nav ul li {
display: inline-block;
float: left;
 }

nav li {
display: inline-block;
margin: 0.75em;
}

nav ul li:last-child {
margin-right: 24px;
}

nav ul li a {
display: inline-block;
outline: none;
color: rgb(255, 255, 255);
text-transform: uppercase;
text-decoration: none;
font-size: 1.2em;
align-content: space-between;
   
font-weight: 600;
}

@media screen and (max-width: 864px) {
.logo {
  padding:0;
}

.nav-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    background: rgb(0, 0, 0);
    opacity: 0;
   transition: all 0.2s ease;
    
  }
  .nav-wrapper ul {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
  }

  .nav-wrapper ul li {
    display: block;
    float: none;
    width: 100%;
    text-align: left;
    margin-bottom: 10px;
  }


.nav-wrapper ul li:nth-child(1) a {
 transition-delay: 0.2s;
 }
  
 .nav-wrapper ul li:nth-child(2) a {
  transition-delay: 0.3s;
  }
  
 .nav-wrapper ul li:nth-child(3) a {
  transition-delay: 0.4s;
 }
  
.nav-wrapper ul li:nth-child(4) a {
 transition-delay: 0.5s;
 }

 .nav-wrapper ul li:nth-child(5) a {
 transition-delay: 0.6s;
 }


.nav-wrapper ul li:not(:first-child) {
 margin-left: 0;
 }
  
.nav-wrapper ul li a {
 padding: 10px 24px;
 opacity: 0;
 color: rgb(255, 255, 255);
 font-size: 14px;
 font-weight: 600;
 letter-spacing: 1.2px;
 transform: translateX(-20px);
 transition: all 0.2s ease;
 }
  
.nav-btn {
 position: fixed;
 right: 10px;
 top: 10px;
 display: block;
 width: 48px;
 height: 48px;
 cursor: pointer;
 z-index: 9999;
 border-radius: 50%;
 }
  
.nav-btn i {
 display: block;
 width: 20px;
 height: 2px;
 background: rgb(255, 255, 255);
 border-radius: 2px;
 margin-left: 14px;
}
  
.nav-btn i:nth-child(1) {
 margin-top: 16px;
}
  
.nav-btn i:nth-child(2) {
 margin-top: 4px;
 opacity: 1;
}
  
.nav-btn i:nth-child(3) {
 margin-top: 4px;
}

}
  
 #nav:checked + .nav-btn {
 transform: rotate(45deg);
  
 }

 #nav:checked + .nav-btn li {
 background: #000;
 transition: transform 0.2s ease;
 }

 #nav:checked + .nav-btn i:nth-child(1) {
 transform: translateY(6px) rotate(180deg);
 }

 #nav:checked + .nav-btn i:nth-child(2) {
  opacity: 0;
 }

 #nav:checked + .nav-btn i:nth-child(3) {
 transform: translateY(-6px) rotate(90deg);
 }

 #nav:checked + .nav-btn i:nth-child(4) {
 opacity: 0;
 }

 #nav:checked ~ .nav-wrapper {
 z-index: 9990;
 opacity: 1;
 }

 #nav:checked ~ .nav-wrapper ul li a {
 opacity: 1;
 transform: translateX(0);
 }

.hidden {
 display: none;
 } 

  .bg-nav {
  background: #000;

  }

 .bg-nav ul {
  padding: 10px;
  }

`

抱歉代码太长 由于我是一个几乎没有 JS 经验的初学者,所以我想知道是否有任何解决方案。 CSS 中是否有任何解决方案,或者我们是否需要使用 JS。 任何帮助将不胜感激

我不认为你可以用 CSS 做到这一点,因为它需要子 -> 父关系。

如果您可以使用 JS,您可以将 #nav 复选框设置为“false”

const onLinkClick = () => {
  document.querySelector("#nav").checked = false; // Once link is clicked -> make #nav checkbox false thus close the menu
};

document
  .querySelectorAll(".nav-wrapper a") // Grab all links
  .forEach((element) => element.addEventListener("click", onLinkClick)); // Listen for click on them