JS中用三种方式实现导航菜单中的二级下拉菜单
网络编程 2021-07-04 20:01www.168986.cn编程入门
我们在淘宝、搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如狼蚁网站SEO优化这张图片。那么如何实现导航菜单栏中的二级下拉菜单呢?狼蚁网站SEO优化长沙网络推广给大家分享JS中用三种方式实现导航菜单中的二级下拉菜单,感兴趣的朋友一起看看吧
我们在淘宝、搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如狼蚁网站SEO优化这张图片。那么如何实现导航菜单栏中的二级下拉菜单?狼蚁网站SEO优化长沙网络推广给大家分享实现思路。
如何实现类似的图片呢?实际上,我们有至少三种方式来实现,狼蚁网站SEO优化,我附上代码供大家参考。
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: #c;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;} /关键一将二级菜单设置为displaynone;/ ul li ul{position: absolute;: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 lang="en"> <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: #c;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;: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: #c;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;: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是非常方便的。
最终的实现效果如下;
即当鼠标划过一级菜单时,会出现相应的二级菜单。
以上所述是长沙网络推广给大家介绍的JS中用三种方式实现导航菜单中的二级下拉菜单,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程