我无法让导航栏停留在窗口顶部。我尝试过使用“粘性数据”,但没有尝试。无论我做什么,它都会随页面一起滚动。我也尝试将该类添加到中小型导航中。有什么建议吗?
HTML:
<!-- Small Navigation -->
<div class="title-bar" data-responsive-toggle="nav-menu" data-hide-for="medium">
<a class="logo-small show-for-small-only" href="#"><img src="/assets/img/fingerLogoXS.gif" /></a>
<button class="menu-icon" type="button" data-toggle></button>
<div class="title-bar-title">Menu</div>
</div>
<!-- Medium-Up Navigation -->
<nav class="top-bar" id="nav-menu">
<div class="logo-wrapper hide-for-small-only">
<div class="logo">
<img src="/assets/img/fingerLogoSM.2.gif">
</div>
</div>
<!-- Left Nav Section -->
<div class="top-bar-left">
<ul class="vertical medium-horizontal menu">
<li><a href="#">Home</a></li>
<li><a href="about.html">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</div>
<!-- Right Nav Section -->
<div class="top-bar-right">
<ul class="vertical medium-horizontal dropdown menu" data-dropdown-menu>
<li class="has-submenu">
<a href="#">Technologies</a>
<ul class="submenu menu vertical medium-horizontal" data-submenu>
<li><a href="#">Foundation</a></li>
<li><a href="#">HTML5</a></li>
<li><a href="#">CSS3</a></li>
<li><a href="#">JavaScript</a></li>
</ul>
</li>
<li>
<a href="#">Portfolio</a>
</li>
</ul>
</div>
</nav>
<!--End Main Navigation-->
的CSS:
/* Small Navigation */
.logo-small {
float: right;
padding: 4px;
}
.title-bar {
padding: 0 .5rem;
background-color: #3D3242;
}
.menu-icon,
.title-bar-title {
position: relative;
top: 10px;
padding: 4px;
}
/* Medium-Up Navigation */
@media only screen and (min-width: 40rem) {
.sticky {
width: 100%;
}
.logo-wrapper {
position: relative;
}
.logo-wrapper .logo {
width: 92px;
height: 92px;
position: absolute;
left: 50%;
right: 50%;
top: -6px;
margin-left: -46px;
}
// Right part
.top-bar-right {
width: 50%;
padding-left: 60px;
}
.top-bar-right ul {
float: left;
}
// Left part
.top-bar-left {
width: 50%;
padding-right: 60px;
}
.top-bar-left ul {
float: right;
}
}
答案 0 :(得分:3)
我在Zurb基金会论坛上得到了很好的帮助。以下是实现粘性TopBar的正确方法:
<div data-sticky-container>
<div class="small-12 sticky" data-sticky data-options="marginTop: 0">
<div class="top-bar">
<div class="top-bar-left">
<ul class="dropdown menu" data-dropdown-menu>
<li class="menu-text">Site Title</li>
<li class="has-submenu">
<a href="#">One</a>
<ul class="submenu menu vertical" data-submenu>
<li><a href="#">One</a></li>
<li><a href="#">Two</a></li>
<li><a href="#">Three</a></li>
</ul>
</li>
<li><a href="#">Two</a></li>
<li><a href="#">Three</a></li>
</ul>
</div>
<div class="top-bar-right">
<ul class="menu">
<li><input type="search" placeholder="Search"></li>
<li><button type="button" class="button">Search</button></li>
</ul>
</div>
</div>
</div>
</div>
再次感谢Val!
答案 1 :(得分:1)
以下是您提出的工作解决方案:https://jsfiddle.net/368z4fun/
使用position:fixed;
轻松解决,如下所示:
.title-bar {
position:fixed;
}
nav {
position:fixed;
}
还添加了一些CSS来修复fixed
更改的样式。请注意使用position:fixed;
的旧移动浏览器兼容性,您可能需要this之类的修复。
您还可以使用StyleBot等浏览器插件在您的实际网站上进行检查。看看这个:
祝你好运!