如何在点击链接时关闭汉堡包
How to make hamburger close upon click of links
我知道之前有人问过这个问题,但我的设置似乎与目前发现的不同。
我的代码如下(顺便说一句,编码真的很糟糕)
<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>
我知道之前有人问过这个问题,但我的设置似乎与目前发现的不同。
我的代码如下(顺便说一句,编码真的很糟糕)
<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>