html css 求助大神:导航栏菜单问题,二级菜单内容会遮盖掉后面的一级菜单栏选项。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了html css 求助大神:导航栏菜单问题,二级菜单内容会遮盖掉后面的一级菜单栏选项。相关的知识,希望对你有一定的参考价值。

导航栏菜单问题,点开第一个导航菜单选项,二级菜单内容会遮盖掉后面的一级菜单栏。怎么解决?

你这个class="n”是不能设置高度的,你设置高度了 肯定会覆盖,取消高度 参考技术A 这样看很难看出具体是哪个,直接上代码吧追问

代码上了

追答

这个还是做成JS的吗,就是点击之后要展开什么的?
用360或其他什么浏览器 按F12 有调试器 直接可以看到哪里的原因

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

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

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

1.仅使用html和css

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<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实现二级下拉菜单

<!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{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>
</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{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>
</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是非常方便的。

 

最终的实现效果如下;

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

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

 

以上是关于html css 求助大神:导航栏菜单问题,二级菜单内容会遮盖掉后面的一级菜单栏选项。的主要内容,如果未能解决你的问题,请参考以下文章

html导航菜单溢出,想搞个可以左右滑动的菜单,请各位大侠帮帮忙!

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

Axure中继器实现二级导航栏

如何为移动屏幕的导航栏项目添加切换按钮,并使用 HTML、CSS 和 Bootstrap v4 将它们切换为下拉菜单

HTML+css 鼠标滑过二级导航时想保留一级导航的滑过 求大神解答

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