JS 实现导航菜单中的二级下拉菜单的几种方式


Posted in Javascript onOctober 31, 2016

最近整理了, JS 实现导航菜单中的二级下拉菜单的三种方式,便于项目中应用。

 如何实现导航菜单栏中的二级下拉菜单?

我们在淘宝、搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如下面这张图片。

JS 实现导航菜单中的二级下拉菜单的几种方式

但是如何实现类似的图片呢?实际上,我们有至少三种方式来实现,下面,我附上代码供大家参考。

1.仅使用html和css

<meta charset="UTF-8">
<title>Document</title>
<style>
*{margin:0;padding: 0;list-style: none;text-decoration: none;}
#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
ul{background: #aaa}
ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
ul li:hover{background: #cea;}
ul li ul li{float: none;}
/*关键一:将二级菜单设置为display:none;*/
ul li ul{position: absolute;top:40px;left: 0; display: none;}
ul li ul li:hover{background: red;}
/*关键二:在划过二级菜单从属的一级菜单时,设置为display:block;*/
ul li:hover ul{display: block;}
</style>
 
 
<div id="nav">
  <ul>
    <li><a href="">首页</a></li>
    <li><a href="">汽车</a>
      <ul>
        <li><a href="#">奥迪</a> </li>
        <li><a href="#">道奇</a> </li>
      </ul>
    </li>
    <li><a href="">手机</a>
      <ul>
        <li><a href="#">小米</a> </li>
        <li><a href="#">华为</a> </li>
      </ul>
    </li>
    <li><a href="">联系我们</a></li>
  </ul>
</div>

我们可以看到,这种方法是比较好的,它保证了结构与表现的完全分离。

2.用javascript实现

<meta charset="UTF-8">
<title>Document</title>
<style>
*{margin:0;padding: 0;list-style: none;text-decoration: none;}
#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
ul{background: #aaa}
ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
ul li:hover{background: #cea;}
ul li ul li{float: none;}
ul li ul{position: absolute;top:40px;left: 0; display:none;}
ul li ul li:hover{background: red;}
</style>
 
 
<div id="nav">
  <ul>
    <li><a href="#">首页</a></li>
    <li onmouseover="show(this)" onmouseout="hide(this)"><a href="#">汽车</a>
  <!-- 关键一:在二级标题从属的一级标题标签内设置时间执行程序,this代表的时这个li元素 -->
      <ul>
        <li><a href="#">奥迪</a> </li>
        <li><a href="#">道奇</a> </li>
      </ul>
    </li>
    <li onmouseover="show(this)" onmouseout="hide(this)"><a href="#">手机</a>
      <ul>
        <li><a href="#">小米</a> </li>
        <li><a href="#">华为</a> </li>
      </ul>
    </li>
    <li><a href="#">联系我们</a></li>
  </ul>
</div>

使用javascript实现起来较为麻烦,且这里结构和行为没有分开(虽然可以试用dom在JavaScript中创建使得结构和行为分开,但十分繁琐),不推荐。

3.用jQuery实现

jQuery是一种javascript库,我们可以在jQuery官网上下载最新版本的库文件,其中压缩的文件是用于产品的,为压缩的文件是便于开发人员学习和调试的。下载到本机以后,需要将库文件引用到html中,由于jQuery本质上也是JavaScript,所以引用方式为:

<script src="路径名称"></script>  

用jQuery实现二级下拉菜单的代码如下:

<meta charset="UTF-8">
<title>Document</title>
<style>
*{margin:0;padding: 0;list-style: none;text-decoration: none;}
#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
ul{background: #aaa}
ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
ul li:hover{background: #cea;}
ul li ul li{float: none;}
ul li ul{position: absolute;top:40px;left: 0; display: none;}
ul li ul li:hover{background: red;}
</style>
 
 
<div id="nav">
  <ul>
    <li><a href="">首页</a></li>
    <li class="navmenu"><a href="">汽车</a>
      <ul>
        <li><a href="#">奥迪</a> </li>
        <li><a href="#">道奇</a> </li>
      </ul>
    </li>
    <li class="navmenu"><a href="">手机</a>
      <ul>
        <li><a href="#">小米</a> </li>
        <li><a href="#">华为</a> </li>
      </ul>
    </li>
    <li><a href="">联系我们</a></li>
  </ul>
</div>

 <!-- 关键一:引入jQuery库文件 -->

 显然,使用jQuery是非常方便的。

 JS 实现导航菜单中的二级下拉菜单的几种方式

最终的实现效果如下;

即当鼠标划过一级菜单时,会出现相应的二级菜单。

 感谢阅读,希望能帮助到大家,谢谢大家对本站支持!

Javascript 相关文章推荐
ExtJS4 组件化编程,动态加载,面向对象,Direct
May 12 Javascript
jsTree 基于JQuery的排序节点 Bug
Jul 26 Javascript
JS对象与JSON格式数据相互转换
Feb 20 Javascript
js事件绑定快捷键以ctrl+k为例
Sep 30 Javascript
JavaScript代码应该放在HTML代码哪个位置比较好?
Oct 16 Javascript
javascript动态添加checkbox复选框的方法
Dec 23 Javascript
jquery树形菜单效果的简单实例
Jun 06 Javascript
javascript this详细介绍
Sep 19 Javascript
bootstrap中的 form表单属性role=&quot;form&quot;的作用详解
Jan 20 Javascript
基于Vue 撸一个指令实现拖拽功能
Oct 09 Javascript
功能完善的小程序日历组件的实现
Mar 31 Javascript
js实现可爱的气泡特效
Sep 05 Javascript
JS中作用域和变量提升(hoisting)的深入理解
Oct 31 #Javascript
jsp 网站引入外部css或者js失效问题解决
Oct 31 #Javascript
js学习笔记之事件处理模型
Oct 31 #Javascript
基于JS实现checkbox全选功能实例代码
Oct 31 #Javascript
新手学习前端之js模仿淘宝主页网站
Oct 31 #Javascript
vue.js学习笔记之绑定style样式和class列表
Oct 31 #Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
Oct 31 #Javascript
You might like
PHP的ASP防火墙
2006/10/09 PHP
基于PHP实现商品成交时发送短信功能
2016/05/11 PHP
PHP请求Socket接口测试实例
2016/08/12 PHP
PHP实现APP微信支付的实例讲解
2018/02/10 PHP
Jsonp 跨域的原理以及Jquery的解决方案
2010/05/18 Javascript
单击按钮显示隐藏子菜单经典案例
2013/01/04 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
location.hash保存页面状态的技巧
2016/04/28 Javascript
卸载安装Node.js与npm过程详解
2016/08/15 Javascript
jQuery 检查某个元素在页面上是否存在实例代码
2016/10/27 Javascript
使用jQuery操作DOM的方法小结
2017/02/27 Javascript
vue.js中实现登录控制的方法示例
2018/04/23 Javascript
详解Angular路由之路由守卫
2018/05/10 Javascript
解决Mac下安装nmp的淘宝镜像失败问题
2018/05/16 Javascript
详解vue-cli3开发Chrome插件实践
2019/05/29 Javascript
JQuery+Bootstrap 自定义全屏Loading插件的示例demo
2019/07/03 jQuery
微信小程序实现购物车代码实例详解
2019/08/29 Javascript
解决Vue在Tomcat8下部署页面不加载的问题
2019/11/12 Javascript
解决Vue项目中tff报错的问题
2020/10/21 Javascript
python实现提取百度搜索结果的方法
2015/05/19 Python
python中使用zip函数出现错误的原因
2018/09/28 Python
django admin组件使用方法详解
2019/07/19 Python
解决Django中调用keras的模型出现的问题
2019/08/07 Python
python网络爬虫 CrawlSpider使用详解
2019/09/27 Python
python3实现在二叉树中找出和为某一值的所有路径(推荐)
2019/12/26 Python
Python之关于类变量的两种赋值区别详解
2020/03/12 Python
Django 删除upload_to文件的步骤
2020/03/30 Python
css3翻牌翻数字的示例代码
2020/02/07 HTML / CSS
一款利用html5和css3动画排列人物头像的实例演示
2014/12/05 HTML / CSS
谈一谈HTML5本地存储技术
2016/03/02 HTML / CSS
数控专业个人求职信范例
2013/11/29 职场文书
社区安全检查制度
2014/02/03 职场文书
八一建军节部队活动方案
2014/02/04 职场文书
事业单位鉴定材料
2014/05/25 职场文书
银行客户经理岗位职责
2015/04/09 职场文书
Spring-cloud Config Server的3种配置方式
2021/09/25 Java/Android