元素隐藏在其他元素后面[关闭]

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()">&times;</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()">&#9776; 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样式下,使菜单按钮出现在顶部。

以上是关于元素隐藏在其他元素后面[关闭]的主要内容,如果未能解决你的问题,请参考以下文章

下拉菜单隐藏在 IE 中的其他元素后面

当光标隐藏在其他 HTML 元素后面时如何触发 mouseenter 事件?

带有视觉跟踪弹出视图的 UISlider。隐藏在其他视图元素后面的弹出窗口

js显示与隐藏元素

如果页面加载时间过长,则隐藏一个元素并显示另一个元素[关闭]

点击除元素以外的任意地方隐藏元素js