元素隐藏在其他元素后面[关闭]
Posted
技术标签:
【中文标题】元素隐藏在其他元素后面[关闭]【英文标题】:elements are hiding behind others [closed] 【发布时间】:2018-03-15 03:26:01 【问题描述】:我正在尝试制作一个 html 页面,该页面具有主页地图和菜单的 sidenav。问题是我无法让 sidenav 打开按钮显示在地图的前面或上方。似乎它总是在它后面,或者如果我弄乱了一些东西,我可以让地图消失,然后 sidenav 打开按钮可见并且工作正常。
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8' />
<title>Test</title>
<meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />
<script src='https://api.tiles.mapbox.com/mapbox-gl-js/v0.44.1/mapbox-gl.js'></script>
<link href='https://api.tiles.mapbox.com/mapbox-gl-js/v0.44.1/mapbox-gl.css' rel='stylesheet' />
<style>/*sidenav*/
html, body
font-family: "Lato", sans-serif;
margin:0;
padding:0;
#map position:absolute; top:0; bottom:0; width:100%;
.sidenav
height: 100%;
width: 0;
position: fixed;
z-index: 1;
top: 0;
left: 0;
background-color: #111;
overflow-x: hidden;
transition: 0.5s;
padding-top: 30px;
.sidenav a, .dropdown-btn
padding: 6px 8px 6px 16px;
text-decoration: none;
font-size: 20px;
color: #818181;
display: block;
border: none;
background: none;
text-align: left;
cursor: pointer;
transition: 0.3s;
.sidenav a:hover, .dropdown-btn:hover
color: #f1f1f1;
#myInput
font-size: 18px;
padding: 6px 8px 6px 16px;
border: none;
border-bottom: 1px solid #ddd;
.main
margin-left: 10px;
font-size: 20px;
padding: 0px 10px;
.active
background-color: #111;
color: white;
.dropdown-container
display: none;
background-color: #262626;
padding-left: 8px;
.fa-caret-down
float: right;
padding-right: 8px;
.sidenav .closebtn
position: absolute;
top: 0;
right: 25px;
font-size: 30px;
margin-left: 50px;
@media screen and (max-height: 450px)
.sidenav padding-top: 15px;
.sidenav a font-size: 18px;
</style>
</head>
<body>
<div id='map'></div>
<script>//this is the map stuff//
mapboxgl.accessToken = 'pk.eyJ1IjoidHJveWIiLCJhIjoiY2pkb3F0cmJnMHA0YTJ4cXB3Mjc0Y3g0eCJ9.3Myq7AzC4yxR8hi9Ubchdw';
var map = new mapboxgl.Map(
container: 'map',
style: 'mapbox://styles/mapbox/streets-v9',
center: [-88.75, 42.15],
zoom: 8
);
</script>
<div id="mySidenav" class="sidenav">
<a href="javascript:void(0)" class="closebtn" onclick="closeNav()">×</a>
<a href="#">Home</a>
<button class="dropdown-btn">Select Congregation
<i class="fa fa-caret-down"></i>
</button>
<div id="myDropdown" class="dropdown-container">
<input type="text" placeholder="Search.." id="myInput" onkeyup="filterFunction()">
<a href="#Mt. Calm">Mt. Calm</a>
<a href="#Newark">Newark</a>
<a href="#Wildwood">Wildwood</a>
</div>
<a href="#">Contact</a>
<a href="#">About</a>
</div>
<div class="main">
<span style="font-size:30px;cursor:pointer" onclick="openNav()">☰ open</span>
<script>
var dropdown = document.getElementsByClassName("dropdown-btn");
var i;
for (i = 0; i < dropdown.length; i++)
dropdown[i].addEventListener("click", function()
this.classList.toggle("active");
var dropdownContent = this.nextElementSibling;
if (dropdownContent.style.display === "block")
dropdownContent.style.display = "none";
else
dropdownContent.style.display = "block";
);
function filterFunction()
var input, filter, ul, li, a, i;
input = document.getElementById("myInput");
filter = input.value.toUpperCase();
div = document.getElementById("myDropdown");
a = div.getElementsByTagName("a");
for (i = 0; i < a.length; i++)
if (a[i].innerHTML.toUpperCase().indexOf(filter) > -1)
a[i].style.display = "";
else
a[i].style.display = "none";
</script>
<script>
function openNav()
document.getElementById("mySidenav").style.width = "260px";
function closeNav()
document.getElementById("mySidenav").style.width = "0";
</script>
</body>
【问题讨论】:
你试过使用z-index吗? 我搞砸了,没有任何结果。如果你能告诉我我需要在哪里设置它,那就太好了! 我对 html 和 JavaScript 完全陌生,所以我需要基本的答案。 【参考方案1】:不要在导航菜单中设置 z-index,而是尝试将 z-index 赋予地图本身
z-index: -1;
顺便说一句,与其给谷歌驱动,不如直接在这写行代码: https://meta.stackexchange.com/questions/51144/how-do-i-post-code-in-***
【讨论】:
完美!我应该想到的。哦,好吧,我是新手,但我正在学习!我不知道我是否应该将这么多代码直接放在我的问题中。 您可以尝试将代码的重要部分发布到 *** 中,但如果您不知道哪个部分重要,请发布所有代码。它仍然比使用谷歌驱动器更好(不可持续,你的驱动器中会有很多未使用的文件,如果你删除它,将来当人们想看到这篇文章时,他们将无法再访问代码) 好的!没想到是这样的。我会这样做的。【参考方案2】:在第 22 行,将宽度的值更改为 200px。您的 sidenav 看起来很好。已检查您的代码。
【讨论】:
他设置width: 0
是因为他想让它通过点击菜单按钮出现,尝试阅读更多代码:)
这对我不起作用。它所做的只是将 X 关闭右上角的侧导航。
.main margin-left: 10px;字体大小:20px;填充:0px 10px;位置:固定;
添加位置:固定在.main css样式下,使菜单按钮出现在顶部。以上是关于元素隐藏在其他元素后面[关闭]的主要内容,如果未能解决你的问题,请参考以下文章
当光标隐藏在其他 HTML 元素后面时如何触发 mouseenter 事件?
带有视觉跟踪弹出视图的 UISlider。隐藏在其他视图元素后面的弹出窗口