当我的页面通过媒体查询调整为移动设备的大小时,我会显示menu bar (handle)
,允许用户click
和slideToggle
导航栏,以便他们可以看到它。< / 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>
答案 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 强>
$(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;