Как показать * просто * меню «гамбургер», когда страница на ширине мобильного телефона? - PullRequest
0 голосов
/ 13 января 2020

Я CSS новичок, пока что использую css только для изменения цвета и размера, копируя и вставляя для таких вещей, как JavaScript. Поэтому я пытаюсь настроить адаптивную панель навигации на сайте w3schools.com, которая обычно выглядит так, как мне нужно.

Моя проблема в том, что ширина экрана уменьшается до ширины мобильного телефона, результата, а также трех строк ( гамбургер), есть также слово «Дом», а не только три строки. Код, который я использовал, взят из https://www.w3schools.com/howto/tryit.asp?filename=tryhow_js_topnav, в то время как моя тестовая страница находится в https://www.abelard.org/mobile/test1.php.

Мне показалось, что раздел кода

@media screen and (max-width: 600px) {
  .topnav a:not(:first-child) {display: none;}
  .topnav a.icon {
    float: right;
    display: block;
  }
}

Мне показалось, что соответствующая область управляет отображением навигационной панели, мое изменение, удаляющее строку .topnav a:not(:first-child) {display: none;}, не имеет значения. Я не вижу, где еще может помочь.

html...
    <!DOCTYPE html>
    <html>
    <head>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="style.css">
    </head>
    <body>

    <div class="topnav" id="myTopnav">
    <a href="#home" class="active">Home</a>
    <a href="#news">News</a>
    <a href="#contact">Contact</a>
    <a href="#about">About</a>
    <a href="javascript:void(0);" class="icon" onclick="myFunction()">
    <img src="/library/menu-burger-grn.png">
    </a>
    </div>

    <div style="padding-left:16px">
    <h2>test page for nav bar</h2>
    <p>First step</p>
    </div>

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

    </body>
    </html>

style.css...

    <style>
    body {
      margin: 0;
      font-family: Arial, Helvetica, sans-serif;
    }

    .topnav {
      overflow: hidden;
      background-color: #333;
    }

    .topnav a {
      float: left;
      display: block;
      color: #f2f2f2;
      text-align: center;
      padding: 14px 16px;
      text-decoration: none;
      font-size: 17px;
    }

    .topnav a:hover {
      background-color: #ddd;
      color: black;
    }

    .topnav a.active {
      background-color: #4CAF50;
      color: white;
    }

    .topnav .icon {
      display: none;
    }

    @media screen and (max-width: 600px) 
      .topnav a.icon {
        float: right;
        display: block;
      }
    }

    @media screen and (max-width: 600px) {
      .topnav.responsive {position: relative;}
      .topnav.responsive .icon {
        position: absolute;
        right: 0;
        top: 0;
      }
      .topnav.responsive a {
        float: none;
        display: block;
        text-align: left;
      }
    }
    </style>
...