如何使汉堡关闭点击链接



我知道以前有人问过这个问题,但我的设置似乎与迄今为止发现的不同。

我的代码如下(顺便说一下,真的不擅长编码(

<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<style>
body {
margin: 0;
font-family:Helvetica;
}
.topnav {
overflow: hidden;
background-color: white;
}
.topnav a {
float: left;
display: block;
color: black;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
.topnav a:hover {
background-color: #add8e6;
color: black;
}
.topnav a.active {
background-color: white;
color: black;
}
.topnav .icon {
display: none;
}
@media screen and (max-width: 1000px) {
.topnav a {display: none;}
.topnav a.icon {
float: right;
display: block;
color: black
}
}
@media screen and (max-width: 1000px) {
.topnav.responsive {position: relative;}
.topnav.responsive .icon {
position: absolute;
right: 0;
top: 0;
}
.topnav.responsive a {
float: none;
display: block;
text-align: left;
}
}
</style>

<div class="topnav" id="myTopnav">
<a href="#vatsatoimii">Toimiva vatsa</a>
<a href="#asiakaspalautteet">Palautteet</a>
<a href="#sisaltoperus">Lyhyt sisältö</a>
<a href="#tarkkasisalto">Tarkka sisältö</a>
<a href="#jasenyys">Jäsenyys ilmaiseksi</a>
<a href="#ukk">UKK</a>
<a href="#sisaltoperus">Hinta</a>
<a href="#kokemukseni">Oma<br>kokemukseni</a>
<a href="javascript:void(0);" class="icon" onclick="myFunction()">
<i class="fa fa-bars"></i>
</a>
</div>
<script>
function myFunction() {
var x = document.getElementById("myTopnav");
if (x.className === "topnav") {
x.className += " responsive";
} else {
x.className = "topnav";
}
}
</script>

不知道点击其中一个锚链接后该怎么做才能使汉堡折叠。

此外,出于某种原因,一些iOS用户表示菜单(不在汉堡中时(在左侧,而不是居中。

谢谢!

您可以向这些导航项添加相同的功能。

let navLinks = document.querySelectorAll('.topnav a:not(.icon)');
navLinks.forEach((link)=>{
link.addEventListener('click', function(e) {
e.preventDefault();
myFunction();
})
});

或者您可以将它添加到所有这些函数中,因为您调用的是同一个函数。

let navLinks = document.querySelectorAll('.topnav a');
navLinks.forEach((link)=>{
link.addEventListener('click', function(e) {
e.preventDefault();
myFunction();
})
});

并将其从您的html:中删除

<a href="#close" class="icon">
<i class="fa fa-bars"></i>
</a>

function myFunction() {
var x = document.getElementById("myTopnav");
if (x.className === "topnav") {
x.className += " responsive";
} else {
x.className = "topnav";
}
}
let navLinks = document.querySelectorAll('.topnav a:not(.icon)');
navLinks.forEach((link)=>{
link.addEventListener('click', function(e) {
e.preventDefault();
myFunction();
})
});
body {
margin: 0;
font-family:Helvetica;
}
.topnav {
overflow: hidden;
background-color: white;
}
.topnav a {
float: left;
display: block;
color: black;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
.topnav a:hover {
background-color: #add8e6;
color: black;
}
.topnav a.active {
background-color: white;
color: black;
}
.topnav .icon {
display: none;
}
@media screen and (max-width: 1700px) {
.topnav a {display: none;}
.topnav a.icon {
float: right;
display: block;
color: black
}
}
@media screen and (max-width: 1700px) {
.topnav.responsive {position: relative;}
.topnav.responsive .icon {
position: absolute;
right: 0;
top: 0;
z-index: 10;
}
.topnav.responsive a {
float: none;
display: block;
text-align: left;
}
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">


<div class="topnav" id="myTopnav">
<a href="#vatsatoimii">Toimiva vatsa</a>
<a href="#asiakaspalautteet">Palautteet</a>
<a href="#sisaltoperus">Lyhyt sisältö</a>
<a href="#tarkkasisalto">Tarkka sisältö</a>
<a href="#jasenyys">Jäsenyys ilmaiseksi</a>
<a href="#ukk">UKK</a>
<a href="#sisaltoperus">Hinta</a>
<a href="#kokemukseni">Oma<br>kokemukseni</a>
<a href="#close" class="icon" onclick="myFunction()">
<i class="fa fa-bars"></i>
</a>
</div>

相关内容

  • 没有找到相关文章

最新更新