HTML+CSS+JavaScript实现下拉菜单效果

Leona ·
更新时间:2024-11-10
· 1869 次阅读

本文实例为大家分享了HTML+CSS+JavaScript实现下拉菜单效果的具体代码,供大家参考,具体内容如下

实现思路:

HTML 方面,导航栏的每个 <li> 元素里面包含 <a> 和 <ul> ,将 <li> 设置为相对定位, 将 <ul> 设置为绝对定位,并将 <ul> 的 display 属性设置为 none 。通过 js 给导航栏的每个 <li> 添加事件监听器,当鼠标覆盖 <li> 时,令 <ul> 的 display 属性值为 block;当鼠标离开 <li> 时,令 <ul> 的 display 属性值为 none;

效果演示:

源代码:

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>下拉菜单</title> <style> * { margin: 0; padding: 0; box-sizing: border-box; } body { background-color: #ffb900; } a { cursor: default; text-decoration: none; font-size: 20px; font-weight: 700; color: #fff; letter-spacing: 3px; } li { list-style: none; cursor: default; } .container { position: absolute; top: 30%; left:50%; transform: translate(-50%, -50%); box-shadow: 0 10px 10px rgba(10, 20, 20, .20), 0 0 10px rgba(10, 20, 20, .20); font-size: 0; } .container .nav { display: inline-block; position: relative; width: 150px; height: 50px; background-color: #505050; text-align: center; line-height: 50px; } .container .nav:hover { background-color: #3e3e3e; } .container .nav ul { display: none; position: absolute; top: 50px; width: 100%; box-shadow: 0 10px 10px rgba(10, 20, 20, .20), 0 0 10px rgba(10, 20, 20, .20); background-color: #fff; text-align: center; } .container .nav ul li a { display: block; color: #505050; } .container .nav ul li a:hover { background-color: #e1e1e1; } </style> </head> <body> <ul class="container"> <li class="nav"> <a href="#">水果</a> <ul> <li><a href="#">西瓜</a></li> <li><a href="#">香蕉</a></li> <li><a href="#">哈密瓜</a></li> <li><a href="#">橙子</a></li> </ul> </li> <li class="nav"> <a href="#">蔬菜</a> <ul> <li><a href="#">西红柿</a></li> <li><a href="#">土豆</a></li> <li><a href="#">小白菜</a></li> <li><a href="#">黄花菜</a></li> </ul> </li> <li class="nav"> <a href="#">酒水</a> <ul> <li><a href="#">啤酒</a></li> <li><a href="#">橙汁</a></li> <li><a href="#">可乐</a></li> <li><a href="#">雪碧</a></li> </ul> </li> <li class="nav"> <a href="#">零食</a> <ul> <li><a href="#">饼干</a></li> <li><a href="#">面包</a></li> <li><a href="#">辣条</a></li> <li><a href="#">沙琪玛</a></li> </ul> </li> </ul> <script> let nav = document.querySelectorAll('.nav'); for(let i=0; i<nav.length; i++) { nav[i].addEventListener('mouseover', function() { this.children[1].style.display = "block"; }); nav[i].addEventListener('mouseout', function() { this.children[1].style.display = "none"; }); } </script> </body> </html>



菜单 HTML JavaScript 下拉菜单 CSS

需要 登录 后方可回复, 如果你还没有账号请 注册新账号