javascript - 打开和关闭侧导航菜单以及导航栏问题

标签 javascript html

我在这里遇到了几个问题。我正在尝试有一个锁定的顶部栏,这确实有效。然而,即使我放置了一些项目,例如橙色动画按钮,它也会出现在文本链接之前的栏上。第二。我希望可以使用动画按钮来关闭页面右侧的弹出菜单。抱歉,如果这真的很简单,我在这里错过了。我仍在学习这些东西。

    function myFunction(x) {
    x.classList.toggle("change");
    }
 
    function openNav() {
    document.getElementById("mySidenav").style.width = "250px";
    }

    function closeNav() {
    document.getElementById("mySidenav").style.width = "0";
    }
    body {
    font-family: "Lato", sans-serif;
    }

    .sidenav {
     height: 100%;
     width: 0;
     position: fixed;
     z-index: 1;
     top: 0;
     right: 0;
     background-color: #111;
     overflow-x: hidden;
     transition: 0.5s;
     padding-top: 60px;
     }

     .sidenav a {
     padding: 8px 8px 8px 32px;
     text-decoration: none;
     font-size: 25px;
     color: #818181;
     display: block;
     transition: 0.3s;
     }

     .sidenav a:hover, .offcanvas a:focus{
     color: #f1f1f1;
     }

     .sidenav .closebtn {
     position: absolute;
     top: 0;
     right: 25px;
     font-size: 36px;
     margin-left: 50px;
     }

    @media screen and (max-height: 450px) {
    .sidenav {padding-top: 15px;}
    .sidenav a {font-size: 18px;}
     }
     
     
    .navbar {
    overflow: hidden;
    background-color: #577CC1;
    position: fixed;
    top: 0;
    width: 100%;
    }

    .navbar a {
    float: right;
    display: block;
    color: #f2f2f2;
    text-align: center;
    padding: 10px 10px;
    text-decoration: none;
    font-size: 17px;
    }

    body {
    margin:0;
    background-color: #ec7c23;
	font-color: ;
	font-size: 10pt;
	font-family: arial;
    height: 1000;
	
    }

    p, td, th {
	font-size: 10pt;
	font-family: arial;
    }

    form {
    margin: 0px;
    padding: 0px;
    }

    .main {
    padding: 10px;
    margin-top: 30px;
    }



     /*animated button*/
     .container {
     display: inline-block;
     cursor: pointer;
     }

    .bar1, .bar2, .bar3 {
    width: 35px;
    height: 5px;
    background-color: #ec7c23;
    margin: 6px 0;
    transition: 0.4s;
    }

    .change .bar1 {
    -webkit-transform: rotate(-45deg) translate(-9px, 6px) ;
    transform: rotate(-45deg) translate(-9px, 6px) ;
    }

    .change .bar2 {opacity: 0;}

    .change .bar3 {
    -webkit-transform: rotate(45deg) translate(-8px, -8px) ;
    transform: rotate(45deg) translate(-8px, -8px) ;
    }
    /*END animated button*/
<div id="mySidenav" class="sidenav">
  <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;
  </a>
  <a href="#">About</a>
  <a href="#">Services</a>
  <a href="#">Clients</a>
  <a href="#">Contact</a>
</div>

<div class="navbar">
  <font size=20 color=white>&nbsp;
    <b>Website</b>
  </font>


  <a href="#link">Link</a>
  <a href="#Link2">Another Link</a>
  <a href="#contact">Contact</a>
  <a href="#about">About</a>

  &nbsp;&nbsp;&nbsp;&nbsp;
  <span style="font-size:30px;cursor:pointer" onclick="openNav()" >
    <div class="container" onclick="myFunction(this)"  >
      <div class="bar1"></div>
      <div class="bar2"></div>
      <div class="bar3"></div>
    </div>
  </span>
</div>

最佳答案

希望这有帮助:

<div class="navbar" style="z-index: 1000">
   <font size=20 color=white>&nbsp;
        <b>Website</b></font>

   <span style="font-size:30px;cursor:pointer;float:right;">
        <div class="container" onclick="myFunction(this)">
            <div class="bar1"></div>
            <div class="bar2"></div>
            <div class="bar3"></div>
        </div>
    </span>
    <a href="#link">Link</a>
    <a href="#Link2">Another Link</a>
    <a href="#contact">Contact</a>
    <a href="#about">About</a> &nbsp;&nbsp;&nbsp;&nbsp;
</div>

<script>
    function myFunction(x) {
        x.classList.toggle("change");
        var mySidenavWidth = document.getElementById("mySidenav").style.width;

        if (mySidenavWidth === "250px")
             closeNav();
        else
             openNav();               
    }
    function openNav() {
        document.getElementById("mySidenav").style.width = "250px";
    }

    function closeNav() {
        document.getElementById("mySidenav").style.width = "0px";
    }
</script>

关于javascript - 打开和关闭侧导航菜单以及导航栏问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45912868/

相关文章:

javascript - 如何将 JSON 日期插入模板

javascript - 使用 JSON 表示法,如何在 javascript 中创建公共(public)方法?

html - div 在悬停时显示,但在使用 active 的移动设备上不显示

HTML/CSS : Having floated element all the way

html - 手机或小浏览器窗口上的文字乱七八糟?

javascript - 如何使用 ng-repeat $index 在数组中查找元素

javascript - 用户友好的单选按钮点击检测

javascript - jquery/javascript 将字符串拆分为 3 个子字符串

html - 将标题和段落环绕图像

html - 我无法使用 css 用颜色填充圆 Angular ?