最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小OO 时间:2020-11-27 20:28:44
文档

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

但是如何实现类似的图片呢?实际上,有至少三种方式来实现,下面,我附上代码供大家参考。仅使用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;top:40px;}<。
推荐度:
导读但是如何实现类似的图片呢?实际上,有至少三种方式来实现,下面,我附上代码供大家参考。仅使用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;top:40px;}<。
在淘宝、搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如下面这张图片。那么如何实现导航菜单栏中的二级下拉菜单?下面小编给大家分享实现思路。

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

仅使用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.用javasc

<。DOCTYPE htm><html><head ><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> script>function show(li){var ul=li.getElementsByTagName("ul")[0];// 关建二:在li这个对象内查询标签名为ul的标签,由于二级标签只有一个,所以索引为0即可。ul.style.display="block";// 关键三:当鼠标划过li时,其子元素ul标签的display为block}function hide(li){var ul=li.getElementsByTagName("ul")[0];ul.style.display="none";// 关键四:当鼠标划出li时,其子元素ul的display为none}/script>

使用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库文件 -->script type="text/javascript">$(function(){$(".navmenu").mouseover(function(){$(this).children("ul").show();})})// 关键二:正确使用jQuey的语法完成行为。$(function(){$(".navmenu").mouseout(function(){$(this).children("ul").hide();})})/script>

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

最终的实现效果如下;

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

但是如何实现类似的图片呢?实际上,有至少三种方式来实现,下面,我附上代码供大家参考。仅使用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;top:40px;}<。
推荐度:
标签: js 方式 如何实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top