zoukankan      html  css  js  c++  java
  • 用三种方式实现导航菜单中的二级下拉菜单

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

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

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

    1.仅使用html和css

    <!DOCTYPE html>
    <html lang="en">
    <head>
    	<meta charset="UTF-8">
    	<title>Document</title>
    	<style>
    	*{margin:0;padding: 0;list-style: none;text-decoration: none;}
    	#nav{ 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>
    </head>
    <body>
    	<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>	
    </body>
    </html>
    

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

     

     

    2.使用javascript实现二级下拉菜单

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    *{margin:0;padding: 0;list-style: none;text-decoration: none;}
    #nav{ 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>
    </head>
    <body>
    <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>
    </body>
    </html>

    3.用jQuery实现二级下拉菜单

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    <style>
        *{margin:0;padding: 0;list-style: none;text-decoration: none;}
        #nav{ 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>
    </head>
    <body>
        <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>
    <script src="jquery-3.1.1.js"></script>
    <!-- 关键一:引入jQuery库文件 -->
    <script type="text/javascript">
    $(function(){
       $(".navmenu").mouseover(function(){
                  $(this).children("ul").show();
    })

    })
    // 关键二:正确使用jQuey的语法完成行为。
    $(function(){
       $(".navmenu") .mouseout(function(){
                 $(this).children("ul").hide();
    })

    })
    </script>
    </body>
    </html>

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

    最终的实现效果如下;

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

      如果大家希望学习关于菜单更多的知识,可以来慕课网学习。

      身不饥寒,天未曾负我;学无长进,我何以对天!

      

  • 相关阅读:
    PHP封装数据库连接
    MySQL和php数据访问
    php测试题
    微信分享缩略图
    js时间戳转时间格式
    php调用微信客服消息接口给用户发送信息
    ueditor富文本
    转:【CSS/JS学习】如何实现单行/多行文本溢出的省略(...)--老司机绕过坑道的正确姿势
    jq实现div移入与移出以及获得与失去焦点
    mysql索引
  • 原文地址:https://www.cnblogs.com/zhuzhenwei918/p/6014538.html
Copyright © 2011-2022 走看看