如何将移动菜单放在内容上?

时间:2017-03-01 17:56:24

标签: html css menu z-index responsive

如果我将设备的宽度缩小到移动菜单,我无法将菜单放在我的内容上,因此菜单变得无法点击。 Z-index对我不起作用。

请问你能帮帮我吗?

代码:

html:

<html>
<head>
</head>
<body>
<div class="bg">
<ul class="topnav" id="myTopnav">
  <li><a href="#home">Home</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>
  <li class="icon">
    <a href="javascript:void(0);" style="font-size:15px;" onclick="myFunction()">☰</a>
  </li>
</ul>

<div class="div1">
</div>
<div class="div2">
</div>
</div>
</body>
</html>

CSS:

html, body {
    padding: 0;
    margin: 0;

}
ul.topnav {
  list-style-type: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: navbar;
}

ul.topnav li {float: left;}

ul.topnav li a {
  display: inline-block;
  color: black;
  text-align: center;
  padding: 14px 16px;
  text-decoration: none;
  transition: 0.3s;
  font-size: 17px;
}

ul.topnav li a:hover {background-color: #555;}
ul.topnav li.icon {display: none;}

@media screen and (max-width:680px) {
  ul.topnav li {display: none;}
  ul.topnav li.icon {
    float: right;
    display: inline-block;
  }
}

@media screen and (max-width:680px) {
  ul.topnav.responsive {position: relative;}
  ul.topnav.responsive li.icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  ul.topnav.responsive li {
    float: none;
    display: inline;
  }
  ul.topnav.responsive li a {
    display: block;
    text-align: left;
  }
}
.bg {
margin: 0;
padding: 0;
background: lightgrey;
position: relative;
height: 500px;
}
.div1
{
background: red;
width: 100px;
position: absolute;
margin: 0 auto;
height: 100px;
bottom: 0;
top: 100px;
left: 0;
right: 0;
}

.div2{
background: green;
width: 100px;
max-width: 100px;
position: absolute;
margin: 0 auto;
height: 100px;
bottom: 0;
top: 300px;
left: 0;
right: 0;
}

JS:

function myFunction() {
  var x = document.getElementById("myTopnav");
  if (x.className === "topnav") {
    x.className += " responsive";
  } else {
    x.className = "topnav";
  }
}

非常感谢!

1 个答案:

答案 0 :(得分:1)

z-index需要应用于ul.topnav,这样才能解决您的问题。

ul.topnav {
  z-index: 99;
}

工作示例:

function myFunction() {
  var x = document.getElementById("myTopnav");
  if (x.className === "topnav") {
    x.className += " responsive";
  } else {
    x.className = "topnav";
  }
}
html,
body {
  padding: 0;
  margin: 0;
}

ul.topnav {
  list-style-type: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: navbar;
  z-index: 99;
}

ul.topnav li {
  float: left;
}

ul.topnav li a {
  display: inline-block;
  color: black;
  text-align: center;
  padding: 14px 16px;
  text-decoration: none;
  transition: 0.3s;
  font-size: 17px;
}

ul.topnav li a:hover {
  background-color: #555;
}

ul.topnav li.icon {
  display: none;
}

@media screen and (max-width:680px) {
  ul.topnav li {
    display: none;
  }
  ul.topnav li.icon {
    float: right;
    display: inline-block;
  }
}

@media screen and (max-width:680px) {
  ul.topnav.responsive {
    position: relative;
  }
  ul.topnav.responsive li.icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  ul.topnav.responsive li {
    float: none;
    display: inline;
  }
  ul.topnav.responsive li a {
    display: block;
    text-align: left;
  }
}

.bg {
  margin: 0;
  padding: 0;
  background: lightgrey;
  position: relative;
  height: 500px;
}

.div1 {
  background: red;
  width: 100px;
  position: absolute;
  margin: 0 auto;
  height: 100px;
  bottom: 0;
  top: 100px;
  left: 0;
  right: 0;
}

.div2 {
  background: green;
  width: 100px;
  max-width: 100px;
  position: absolute;
  margin: 0 auto;
  height: 100px;
  bottom: 0;
  top: 300px;
  left: 0;
  right: 0;
}
<div class="bg">
  <ul class="topnav" id="myTopnav">
    <li><a href="/">Home</a></li>
    <li><a href="/">News</a></li>
    <li><a href="/">Contact</a></li>
    <li><a href="/">About</a></li>
    <li class="icon">
      <a href="javascript:void(0);" style="font-size:15px;" onclick="myFunction()">☰</a>
    </li>
  </ul>

  <div class="div1">
  </div>
  <div class="div2">
  </div>
</div>