javascript - 单击后如何关闭此菜单

标签 javascript jquery menu

我正在尝试自定义 This menu

这是 html 标记:

<ul class="topnav" id="myTopnav">
  <li id="links"><a href="#home">Home</a></li>
  <li id="links"><a href="#news">News</a></li>
  <li id="links"><a href="#contact">Contact</a></li>
  <li id="links"><a href="#about">About</a></li>
  <li class="icon">
    <a href="javascript:void(0);" onclick="myFunction()">&#9776;</a>
  </li>
</ul>

CSS:

ul.topnav {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    background-color: #333;
}

ul.topnav li {float: left;}

ul.topnav li a {
    display: inline-block;
    color: #f2f2f2;
    text-align: center;
    padding: 14px 16px;
    text-decoration: none;
    transition: 0.3s;
    font-size: 17px;
}

ul.topnav li a:hover {background-color: #555;}

ul.topnav li.icon {display: none;}

@media screen and (max-width:1180px) {
  ul.topnav li:not(:first-child) {display: none;}
  ul.topnav li.icon {
    float: right;
    display: inline-block;
  }
}

@media screen and (max-width:680px) {
  ul.topnav.responsive {position: relative;}
  ul.topnav.responsive li.icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  ul.topnav.responsive li {
    float: none;
    display: inline;
  }
  ul.topnav.responsive li a {
    display: block;
    text-align: left;
  }
}

还有 JS:

function myFunction() {
    var x = document.getElementById("myTopnav");
    if (x.className === "topnav") {
        x.className += " responsive";
    } else {
        x.className = "topnav";
    }
}

我正在尝试添加此选项以使菜单在用户单击任何列表项后关闭-

$(document).ready(function($) {
    $('#links').click(function() {
       $("#myTopnav").removeClass("topnav");
    });
});

但这似乎不起作用。

知道如何解决这个问题吗?

最佳答案

id 属性在同一文档中应该是唯一的,按类替换重复的属性:

<ul class="topnav" id="myTopnav">
    <li class="links"><a href="#home">Home</a></li>
    <li class="links"><a href="#news">News</a></li>
    <li class="links"><a href="#contact">Contact</a></li>
    <li class="links"><a href="#about">About</a></li>
    <li class="icon">
      <a href="javascript:void(0);" onclick="myFunction()">&#9776;</a>
    </li>
</ul>

在 JS 代码中使用类选择器 . :

$(document).ready(function($) {
    $('.links').click(function() {
       $("#myTopnav").removeClass("responsive");
    });
});

注意:您必须删除 responsive 类,而不是 topnav

希望这有帮助。

function myFunction() {
  var x = document.getElementById("myTopnav");
  if (x.className === "topnav") {
    x.className += " responsive";
  } else {
    x.className = "topnav";
  }
}

$(document).ready(function($) {
  $('.links').click(function() {
    $("#myTopnav").removeClass("responsive");
  });
});
ul.topnav {
  list-style-type: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: #333;
}

ul.topnav li {float: left;}

ul.topnav li a {
  display: inline-block;
  color: #f2f2f2;
  text-align: center;
  padding: 14px 16px;
  text-decoration: none;
  transition: 0.3s;
  font-size: 17px;
}

ul.topnav li a:hover {background-color: #555;}

ul.topnav li.icon {display: none;}

@media screen and (max-width:1180px) {
  ul.topnav li:not(:first-child) {display: none;}
  ul.topnav li.icon {
    float: right;
    display: inline-block;
  }
}

@media screen and (max-width:680px) {
  ul.topnav.responsive {position: relative;}
  ul.topnav.responsive li.icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  ul.topnav.responsive li {
    float: none;
    display: inline;
  }
  ul.topnav.responsive li a {
    display: block;
    text-align: left;
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="topnav" id="myTopnav">
  <li class="links"><a href="#home">Home</a></li>
  <li class="links"><a href="#news">News</a></li>
  <li class="links"><a href="#contact">Contact</a></li>
  <li class="links"><a href="#about">About</a></li>
  <li class="icon">
    <a href="javascript:void(0);" onclick="myFunction()">&#9776;</a>
  </li>
</ul>

关于javascript - 单击后如何关闭此菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38507026/

相关文章:

jquery - 无法在 spring mvc 形式中使用ajax

jquery - 跨浏览器 css 样式建议

java - 错误 : the constructor intent is undefined

javascript - Threejs 波纹板定制形状

javascript - Angular 8 - FormBuilder.group 不保留数组

javascript - 使用自动完成功能时从数据库传递隐藏值

Javascript setInterval 函数不能重复

javascript - 根据变量值检查单选按钮

menu - 带 anchor 的 Typo3 菜单

menu - 如何从串行端口列表中将菜单项添加到 Electron 菜单