媒体查询的导航栏问题

时间:2016-12-31 23:51:10

标签: javascript jquery html css

当我的页面通过媒体查询调整为移动设备的大小时,我会显示menu bar (handle),允许用户clickslideToggle导航栏,以便他们可以看到它。< / p>

当我手动调整页面大小时,我注意到以下问题:

当我在移动视图中,并且导航栏可见时,然后当我调整其大小时,导航栏可见。但是,如果我在移动视图中关闭导航栏,然后调整大小全屏,我的导航栏就会消失,我不知道为什么。我相信我的jQuery存在问题。有人能指出我正确的方向吗?

$(document).ready(function() {
  var handle = $(".handle");
  var navigation = $(".navigation");
  handle.click(function() {
    navigation.slideToggle();
  });
});
nav ul {
  background-color: #43a286;
  overflow: hidden;
  color: white;
  padding: 0;
  text-align: center;
  margin: 0;
}
nav ul li:hover {
  background-color: #399077;
  transition: 0.5s;
}
nav ul li {
  display: inline-block;
  padding: 20px;
}
.handle {
  width: 100%;
  background: #005c48;
  text-align: left;
  box-sizing: border-box;
  padding: 15px;
  color: white;
  display: none;
}
.handle i {
  float: right;
  cursor: pointer;
}
@media screen and (max-width: 400px) {
  nav ul li {
    box-sizing: border-box;
    width: 100%;
    display: block;
    padding: 15px;
    text-align: left;
    box-shadow: 1px 1px #399077;
  }
  .handle {
    display: block;
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<nav>
  <div class="handle">Menu</div>
  <ul class="navigation">
    <a href="#"><li>Home</li></a>
    <a href="#"><li>About</li></a>
    <a href="#"><li>Service</li></a>
    <a href="#"><li>Contact</li></a>
  </ul>
</nav>

2 个答案:

答案 0 :(得分:0)

如果您点击slideToggle.handle导航菜单,则会隐藏它。如果您要调整窗口大小(隐藏导航后) - 它仍然会被隐藏(因为您没有做任何事情再次显示它)。

调整窗口大小后,您可以使用resize event运行任何其他功能(请注意,您需要检查resize是缩小或放大窗口,然后您需要检查导航是否可见 - 然后显示它(如果它被隐藏)。

答案 1 :(得分:0)

切换回桌面视图后,您需要将导航从隐藏重置为可见,否则如果导航被隐藏,它将保持隐藏状态。您可以通过resize()函数

来完成
$(document).ready(mobileNav);
$(window).on('resize', mobileNav);

function mobileNav() {
  var handle = $(".handle");
  var navigation = $(".navigation");
  if (window.innerWidth <= 400) {
    navigation.hide();
  } else {
    navigation.show();
  }
  handle.unbind().click(function() {
    navigation.slideToggle();
  });
}

此外,<a>不允许直接<ul>,因此请将其移至<li> s。

<强> jsFiddle

&#13;
&#13;
$(document).ready(mobileNav);
$(window).on('resize', mobileNav);

function mobileNav() {
  var handle = $(".handle");
  var navigation = $(".navigation");
  if (window.innerWidth <= 400) {
    navigation.hide();
  } else {
    navigation.show();
  }
  handle.unbind().click(function() {
    navigation.slideToggle();
  });
}
&#13;
nav ul {
  background-color: #43a286;
  overflow: hidden;
  color: white;
  padding: 0;
  text-align: center;
  margin: 0;
}
nav ul li:hover {
  background-color: #399077;
  transition: 0.5s;
}
nav ul li {
  display: inline-block;
}
nav ul li a {
  display: block;
  padding: 20px;
  color: #fff;
}
.handle {
  width: 100%;
  background: #005c48;
  text-align: left;
  box-sizing: border-box;
  padding: 15px;
  color: white;
  display: none;
}
.handle i {
  float: right;
  cursor: pointer;
}
@media screen and (max-width: 400px) {
  nav ul li {
    box-sizing: border-box;
    width: 100%;
    display: block;
    text-align: left;
    box-shadow: 1px 1px #399077;
  }
  nav ul li a {
    padding: 15px;
  }
  .handle {
    display: block;
  }
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<nav>
  <div class="handle">Menu</div>
  <ul class="navigation">
    <li><a href="#">Home</a></li>
    <li><a href="#">About</a></li>
    <li><a href="#">Service</a></li>
    <li><a href="#">Contact</a></li>
  </ul>
</nav>
&#13;
&#13;
&#13;