但是如何实现类似的图片呢?实际上,有至少三种方式来实现,下面,我附上代码供大家参考。
仅使用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