html导航栏菜单js
时间: 2023-08-23 10:03:42 浏览: 34
下面是一个基本的 HTML 导航栏菜单,使用 JavaScript 实现菜单栏的下拉效果:
```html
<!DOCTYPE html>
<html>
<head>
<title>导航栏菜单</title>
<style>
ul {
list-style-type: none;
margin: 0;
padding: 0;
overflow: hidden;
background-color: #333;
}
li {
float: left;
}
li a, .dropbtn {
display: inline-block;
color: white;
text-align: center;
padding: 14px 16px;
text-decoration: none;
}
li a:hover, .dropdown:hover .dropbtn {
background-color: red;
}
li.dropdown {
display: inline-block;
}
.dropdown-content {
display: none;
position: absolute;
background-color: #f9f9f9;
min-width: 160px;
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
z-index: 1;
}
.dropdown-content a {
color: black;
padding: 12px 16px;
text-decoration: none;
display: block;
text-align: left;
}
.dropdown-content a:hover {
background-color: #f1f1f1;
}
.show {
display: block;
}
</style>
</head>
<body>
<ul>
<li><a class="active" href="#home">Home</a></li>
<li><a href="#news">News</a></li>
<li><a href="#contact">Contact</a></li>
<li class="dropdown">
<a href="javascript:void(0)" class="dropbtn">Dropdown</a>
<div class="dropdown-content">
<a href="#">Link 1</a>
<a href="#">Link 2</a>
<a href="#">Link 3</a>
</div>
</li>
</ul>
<script>
/* 当点击下拉按钮时显示/隐藏下拉内容 */
document.getElementsByClassName("dropbtn")[0].onclick = function() {
document.getElementsByClassName("dropdown-content")[0].classList.toggle("show");
}
/* 当用户点击文档的其他地方时隐藏下拉内容 */
window.onclick = function(event) {
if (!event.target.matches('.dropbtn')) {
var dropdowns = document.getElementsByClassName("dropdown-content");
var i;
for (i = 0; i < dropdowns.length; i++) {
var openDropdown = dropdowns[i];
if (openDropdown.classList.contains('show')) {
openDropdown.classList.remove('show');
}
}
}
}
</script>
</body>
</html>
```
这段代码中,我们首先定义了一个 `<ul>` 元素作为我们的导航栏,其中包含若干个 `<li>` 元素。其中,一个带有 `dropdown` 类名的 `<li>` 元素表示一个下拉菜单。
当用户点击下拉按钮时,我们使用 JavaScript 来切换 `dropdown-content` 类的 `show` 属性,从而显示或隐藏下拉内容。同时,我们还监听了整个文档的点击事件,当用户点击文档的其他地方时,隐藏下拉内容。