我在设计响应式布局时遇到了一些麻烦,如下所示:
如果您浏览到http://www.wickersleysixthform.net,您可以看到这一点。
基本上我正在尝试创建一个响应式菜单,因此在 768 像素及以上的浏览器中,您将看到正常的水平导航。然后对于 481 像素以下的任何内容,您将看到带有 .slideToggle() 效果的“三行”菜单,一旦按下下拉菜单。
我可以让这个工作,但 .slideToggle() 并没有推动我需要它做的其余内容。如果我手动调整浏览器屏幕的大小,这三行也不会出现,但是如果我调整大小然后刷新页面,它会这样做,但如果我这样做,则不会显示较大屏幕尺寸的正常链接。我希望这是有道理的。
这是我在 jQuery(document).ready(function($) {}); 中用于切换的 jQuery。
/* getting viewport width */
var responsive_viewport = $(window).width();
/* if is below 481px */
if (responsive_viewport < 481) {
$(".top-nav").before('<div id="menu">☰</div>');
$("#menu").click(function(){
$(".top-nav").slideToggle();
});
}
/* if is above or equal to 768px */
if (responsive_viewport >= 768) {
$(".top-nav").show();
}
任何人都可以帮忙吗?毫无疑问,这很简单,但它让我发疯。可能基于 CSS 而不是 jQuery?
我使用的 CSS 如下(在我的基本/移动样式表中)。
.header {
background-color:@blue;
padding-top:10px;
height:50px;
}
#menu {
display:block;
font-size:1.75em;
position: absolute;
right: 10px;
top: 2px;
}
.top-nav {
display:none;
}
.top-nav.open {
display:block;
background:@blue;
}
在我的 768 及以上样式表中:
.header {
padding-top:0;
height:70px;
position:fixed;
width:100%;
z-index:10;
}
#menu {
display:none;
}
.top-nav {
display:block;
}
我的 HTML 结构:
<header class="header" role="banner">
<div id="inner-header" class="wrap clearfix">
<a rel="nofollow" href="http://www.wickersleysixthform.net">
<img id="logo" width="50px" height="36px" src="http://www.wickersleysixthform.net/wp-content/themes/sixthform/library/images/white.png">
</a>
<nav role="navigation">
<div id="menu">☰</div>
<ul id="menu-main-menu" class="nav top-nav clearfix">
<li><a href="http://www.wickersleysixthform.net/">About</a></li>
<li>
<a href="http://www.wickersleysixthform.net/current/">Current Students</a>
<ul class="sub-menu"></ul>
</li>
<li><a href="http://www.wickersleysixthform.net/courses/">Courses</a></li>
<li><a href="http://www.wickersleysixthform.net/student-life/">Student Life</a></li>
<li><a href="#">Prospectus</a></li>
<li><a href="http://www.wickersleysixthform.net/apply/">Apply</a></li>
<li><a href="http://www.wickersleysixthform.net/contact/">Contact</a></li>
</ul>
</nav>
</div>
</header>