【发布时间】:2017-09-28 03:48:15
【问题描述】:
一旦用户滚动页面,我想让导航栏粘在视口的顶部,但它不起作用,我不知道为什么。如果你能帮忙,这是我的 HTML 和 CSS 代码:
.container {
min-height: 300vh;
}
.nav-selections {
text-transform: uppercase;
letter-spacing: 5px;
font: 18px "lato",sans-serif;
display: inline-block;
text-decoration: none;
color: white;
padding: 18px;
float: right;
margin-left: 50px;
transition: 1.5s;
}
.nav-selections:hover{
transition: 1.5s;
color: black;
}
ul {
background-color: #B79b58;
overflow: auto;
}
li {
list-style-type: none;
}
<main class="container">
<nav style="position: sticky; position: -webkit-sticky;">
<ul align="left">
<li><a href="#/contact" class="nav-selections" style="margin-right:35px;">Contact</a></li>
<li><a href="#/about" class="nav-selections">About</a></li>
<li><a href="#/products" class="nav-selections">Products</a></li>
<li><a href="#" class="nav-selections">Home</a></li>
</ul>
</nav>
</main>
【问题讨论】:
-
position:sticky 需要一个坐标来告诉你粘贴在哪里
-
您还必须小心父元素。
position: stickycan stop working if it's inside a flexbox unless you're careful 并且如果在它和它在里面滚动的任何东西之间有一个overflow: hidden或overflow: auto也会失败(主体根或最近的祖先溢出:滚动) -
@user56reinstatemonica8 OMG 感谢kkkyou 告诉我有关
overflow: hidden和overflow: auto的信息!几天来我一直在摸不着头脑,试图让这个废话发挥作用 -
我写了一篇关于粘性定位的文章,如果你有兴趣可以在这里查看:dioxmio.medium.com/sticky-done-the-right-way-880af0122a71
-
@user56reinstatemonica8 谢谢,对我来说它失败了,因为我在 flexbox 中使用了它。
标签: html css position css-position sticky