我正在建立一个下拉菜单.同样,当我打开一个子菜单时,它保持打开状态,即使我打开了第二个子菜单.当我打开第二个子菜单时,它应该会关闭任何其他打开的菜单.
const submenuLinks = document.querySelectorAll('.has-submenu > a');
submenuLinks.forEach(element => element.addEventListener('click', function(e) {
var submenu = element.nextElementSibling;
if (submenu.classList.contains('menu-hide')) {
submenu.classList.add('menu-show');
submenu.classList.remove('menu-hide');
} else {
submenu.classList.add('menu-hide');
submenu.classList.remove('menu-show');
}
}));
.menu-hide {
display: none;
}
.menu-show {
display: block;
}
<nav>
<ul class="menu">
<li>
<a href="#">Menu Item 1</a>
</li>
<li class="has-submenu">
<a href="#">Menu Item 2 »</a>
<ul class="menu-sub menu-hide">
<li><a href="#">Submenu Item 1</a></li>
<li><a href="#">Submenu Item 2</a></li>
<li><a href="#">Submenu Item 3</a></li>
</ul>
</li>
<li class="has-submenu">
<a href="#">Menu Item 3 »</a>
<ul class="menu-sub menu-hide">
<li><a href="#">Submenu Item 1</a></li>
<li><a href="#">Submenu Item 2</a></li>
<li><a href="#">Submenu Item 3</a></li>
</ul>
</li>
</ul>
</nav>