首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js二级下拉菜单代码

JavaScript二级下拉菜单是一种常见的网页交互元素,它允许用户通过点击主菜单项来展开或收起子菜单项。下面是一个简单的二级下拉菜单的示例代码,包括HTML、CSS和JavaScript部分。

HTML部分

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>二级下拉菜单示例</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>

<nav class="navbar">
  <ul class="nav-list">
    <li class="nav-item"><a href="#">首页</a></li>
    <li class="nav-item dropdown">
      <a href="#" class="dropbtn">产品</a>
      <div class="dropdown-content">
        <a href="#">产品1</a>
        <a href="#">产品2</a>
        <a href="#">产品3</a>
      </div>
    </li>
    <li class="nav-item"><a href="#">关于我们</a></li>
    <li class="nav-item"><a href="#">联系我们</a></li>
  </ul>
</nav>

<script src="script.js"></script>
</body>
</html>

CSS部分(styles.css)

代码语言:txt
复制
.navbar {
  background-color: #333;
}

.nav-list {
  list-style-type: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.nav-item {
  float: left;
}

.nav-item a, .dropbtn {
  display: inline-block;
  color: white;
  text-align: center;
  padding: 14px 16px;
  text-decoration: none;
}

.nav-item a:hover, .dropdown:hover .dropbtn {
  background-color: #111;
}

.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;
}

.dropdown:hover .dropdown-content {
  display: block;
}

JavaScript部分(script.js)

代码语言:txt
复制
// 如果需要使用JavaScript来控制下拉菜单的显示和隐藏,可以使用以下代码
document.addEventListener('DOMContentLoaded', function() {
  var dropdowns = document.querySelectorAll('.dropdown');
  dropdowns.forEach(function(dropdown) {
    dropdown.addEventListener('click', function(event) {
      event.preventDefault();
      this.querySelector('.dropdown-content').classList.toggle('show');
    });
  });

  // 点击下拉菜单外部时关闭所有下拉菜单
  window.addEventListener('click', function(event) {
    if (!event.target.matches('.dropbtn')) {
      var dropdowns = document.querySelectorAll('.dropdown-content');
      dropdowns.forEach(function(dropdown) {
        if (dropdown.classList.contains('show')) {
          dropdown.classList.remove('show');
        }
      });
    }
  });
});

优势和应用场景

  • 用户体验:二级下拉菜单可以提供更丰富的导航选项,使用户能够更直观地找到所需信息。
  • 空间效率:相比于多级菜单,二级下拉菜单可以节省屏幕空间,特别是在移动设备上。
  • 应用场景:适用于网站导航、电子商务网站的产品分类、企业网站的部门导航等。

可能遇到的问题及解决方法

  1. 下拉菜单不显示:检查CSS中.dropdown-contentdisplay属性是否正确设置为none,并且在:hover状态下是否设置为block
  2. JavaScript控制无效:确保JavaScript代码正确绑定到DOM元素,并且事件监听器设置无误。
  3. 兼容性问题:在不同浏览器中测试下拉菜单的表现,必要时使用CSS前缀或Polyfill来解决兼容性问题。

通过以上代码和说明,你应该能够创建一个基本的二级下拉菜单,并了解其优势和应用场景。如果遇到具体问题,可以根据上述解决方法进行调试。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Excel: 设置动态的二级下拉菜单

    本文要讲述的是如何通过offset、match和counta函数,得到动态的二级下拉菜单。...A:A)-1,1) 通过函数offset产生动态的一级下拉菜单,好处是后期如果要添加新的省份名称,那么单元格名称省份的内容也会动态更新。...如果数据源输入的内容是Counter,则下拉菜单中会出现很多空白项。因此,这里通过COUNTA(Counter),来获得对应城市的可选项个数,再通过OFFSET(参数表!...参考资料: [1] 求助动态二级下拉菜单的制作(https://club.excelhome.net/thread-1620256-1-1.html) [2] OFFSET 函数(https://support.microsoft.com...support.microsoft.com/zh-cn/office/index-%E5%87%BD%E6%95%B0-a5dcf0dd-996d-40a4-a822-b56b061328bd) [6] Excel里面如何建立二级下拉菜单

    4.9K10

    html二级菜单:DIV+CSS制作二级菜单(横排二级下拉菜单)以及二级菜单出现错位怎么解决「建议收藏」

    html二级菜单制作(横排二级下拉菜单)以及二级菜单出现错位怎么解决 摘要:DIV+CSS制作二级菜单(横排二级下拉菜单)以及二级菜单出现错位怎么解决(解决办法放在代码下面) 1.先看一下最终的效果图...来先看具体代码吧,设计的具体思路就放在代码下面哈哈哈ヾ(≧▽≦*)o 3.二级菜单出现错位解决办法如下: 错位原因:再css样式里即内没有添加去掉网页原有属性的代码(* { margin:0; padding:0;}),接下来我把源代码里的...3.接着在一级菜单里嵌入二级菜单即一级菜单二级菜单 4.嵌入后接下来控制二级菜单的样式,通过绝对定位使二级菜单出现在一级菜单下然后隐藏即...5.最后,当鼠标移动到一级菜单上时二级菜单这时时显示不出来的,还需要添加“ul li:hover ul{ display:block}”使二级菜单显示出来;下面的文字部分和图片部分是用两个小盒子,通过类选择器独立控制各自的样式

    5.6K10

    怎样保持下拉菜单并截图?如何快速截图二级菜单?

    我也是研究了半天才试出来,上次想这样截没弄好最后放弃了 浏览器快捷键截图 打开浏览器,点击截图下拉菜单,会发现浏览器自带截图快捷键,大部分是“Ctrl+Shift+X”。...可以将浏览器最小化,打开任意软件点击任一下拉菜单,然后按住“Ctrl+Shift+X”,会发现鼠标指针已经变成彩色,就可以截图了。...(这点可根据你的想法自己设定,只要不跟其它热键冲突,即可) 3.截图前,先按住“Shift+Alt+Ctrl”键,然后鼠标点击,显示下拉菜单。...4.下拉菜单出来以后,松手Shift,继续按住Ctrl+Alt键不放,同时再按住A键。(因为笔者设置的快捷键是“Ctrl+Alt+A”).这时鼠标指针就变成彩色,可以截图了。

    2.3K20

    调试JS代码

    记录下近期对JS代码的调试过程 性能分析 启动程序之后,打开google浏览器对应页面,按F12或者Ctrl+Shift+I进入 开发者工具页面 目前主要使用的功能有: Performance....性能评估,比如我想看下页面刷新的性能瓶颈所在,先点击 按钮,然后进行页面操作,当页面刷新完成,再点击 按钮,则会生成性能报告,可以看到资源消耗,JS代码的执行逻辑等 Sources....性能报告页面的 部分,可以通过点击色块查看其所在的js代码文件,如 点击则会跳转到 功能栏,有了源文件就可以进行断点调试;这里注意部分js文件是压缩后的文件,建议手动修改程序替换成可读性更强的原始代码文件...查看程序的打印输出,比如我想知道某个函数的执行时间,可以在js代码中进行修改 当js代码执行之后,可以在console输出中看到foo的执行时间 Network....代码使用for循环进行操作,也就是线性复杂度,计算耗时随数据量的增大而线性增大 通过debug观察发现颜色数组会有不少重复的数值,而同样的输入会导致相同的输出,然后对整个数据的1M个点进行统计分析,发现重复率相当高

    19K10

    js代码规范

    前言 在js的代码开发中,我简单的总结出了以下规则,后面会陆续补充并且对规范进行分类。...js代码建议保存到后缀名.js的文件中 js代码不建议放在html中,原因有:不能被缓存,会增大网页文件的大小,可维护性不高,会影响页面的加载。...js吧任何表达式都当一条简单语句,会导致一些隐性的错误。如果自己没加分号,那么js解释器会自动添加分号,按照自己能读懂的断句。 9.2 复合语句 也称为语句块,被包在大括号内部。...比如对象 var obj={} ;var arr=[] eval eval是最容易混乱使用的js函数,他可以执行内部入参的js函数或者表达式,可以直接解析变量。不建议使用 。...尽量使用语法严格模式 消除代码之中的不友好;代码运行更快 ;保证运行的安全 ;为新版本的js做好铺垫。 22.

    8.9K30

    JS代码混淆 | js 逆向系列

    /UglifyJS/ https://github.com/LiPinghai/UglifyJSDocCN/blob/master/README.md 使用方法 npm install uglify-js...-g uglifyjs example.js -c -m --mangle-props -c 代码压缩 -m 代码混淆 --mangle-props 混淆属性名 -b 美化显示 // 原代码 const...JShaman https://www.jshaman.com/ JShaman 是国内公司开发的js代码加密商业产品 免费版可以直接使用 // 原代码 const person = { age...,通过数组、字典等各种形式存储、拼接、替换等,最终进行还原,这里面没有利用到复杂的语法以及js 语言本身的特性,所以我们一点点解开也学不到什么; 这个代码就不一样了,我们一步一步解开它,尝试去学习其中的思路...console.log(c) 这次我们设计三个返回值,分别是函数定义、数值、字符串 看到这,我都蒙了,经过查询资料,我找到了两个维度的复杂的原因 JavaScript 中函数只能有一个返回值,你就说这玩意如果没学过 js

    2.6K10
    领券