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 相关文章推荐
js实现幻灯片效果(基于jquery插件)
Nov 05 Javascript
动态加载脚本提升javascript性能
Feb 24 Javascript
Javascript基础教程之数据类型 (布尔型 Boolean)
Jan 18 Javascript
js获取图片宽高的方法
Nov 25 Javascript
jQuery实现ajax的叠加和停止(终止ajax请求)
Aug 08 Javascript
javascript使用递归算法求两个数字组合功能示例
Jan 03 Javascript
详解webpack 多页面/入口支持&amp;公共组件单独打包
Jun 29 Javascript
vue使用axios实现文件上传进度的实时更新详解
Dec 20 Javascript
通过vue-cli来学习修改Webpack多环境配置和发布问题
Dec 22 Javascript
微信小程序request请求封装,验签代码实例
Dec 04 Javascript
React.js组件实现拖拽排序组件功能过程解析
Apr 27 Javascript
vue任意关系组件通信与跨组件监听状态vue-communication
Oct 18 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
鼠标图片振动代码
2006/07/06 Javascript
javascript 计算两个整数的百分比值
2009/12/26 Javascript
js登录弹出层特效
2014/03/07 Javascript
JavaScript使用循环和分割来替换和删除元素实例
2014/10/13 Javascript
简介JavaScript中的getSeconds()方法的使用
2015/06/10 Javascript
深入浅析AngularJS中的module(模块)
2016/01/04 Javascript
AnjularJS中$scope和$rootScope的区别小结
2016/09/18 Javascript
前端js弹出框组件使用方法
2020/08/24 Javascript
基于input框覆盖掉数字英文的实例讲解
2017/07/21 Javascript
js微信应用场景之微信音乐相册案例分享
2017/08/11 Javascript
写一个移动端惯性滑动&amp;回弹Vue导航栏组件 ly-tab
2018/03/06 Javascript
jQuery实现百度图片移入移出内容提示框上下左右移动的效果
2018/06/05 jQuery
javascript显示动态时间的方法汇总
2018/07/06 Javascript
vue将毫秒数转化为正常日期格式的实例
2018/09/16 Javascript
nodejs中各种加密算法的实现详解
2019/07/11 NodeJs
纯js+css实现仿移动端淘宝网站的弹出详情框功能
2019/12/29 Javascript
[01:56]无止竞 再出发——中国军团出征2017年DOTA2国际邀请赛
2017/07/05 DOTA
python类参数self使用示例
2014/02/17 Python
python提取内容关键词的方法
2015/03/16 Python
Python2.7编程中SQLite3基本操作方法示例
2017/08/09 Python
Python实现的双色球生成功能示例
2017/12/18 Python
Python中py文件引用另一个py文件变量的方法
2018/04/29 Python
一看就懂得Python的math模块
2018/10/21 Python
python 构造三维全零数组的方法
2018/11/12 Python
Python3中lambda表达式与函数式编程讲解
2019/01/14 Python
python字典改变value值方法总结
2019/06/21 Python
Python2.7版os.path.isdir中文路径返回false的解决方法
2019/06/21 Python
教你如何编写、保存与运行Python程序的方法
2019/07/12 Python
python 遗传算法求函数极值的实现代码
2020/02/11 Python
详解CSS3实现响应式手风琴效果
2020/06/10 HTML / CSS
综合实践活动方案
2014/02/14 职场文书
教师现实表现材料
2014/02/14 职场文书
幼儿园教研活动总结
2014/04/30 职场文书
服装发布会策划方案
2014/05/22 职场文书
物理教育专业求职信
2014/06/25 职场文书
春游踏青活动方案
2014/08/14 职场文书