.parent {
overflow: hidden;
}
.child {
position: sticky;
top: 0;
}
<div class="container">
<div class="sidebar">...</div>
<div class="content">...</div>
</div>
.container {
display: flex;
}
.sidebar {
position: sticky;
top: 0;
}
.sticky {
position: sticky;
}
.sticky {
position: sticky;
top: 0; /* 吸附到顶部 */
}
<div class="section">
<h2 class="sticky">章节标题</h2>
<p>一大段内容</p>
</div>
.section {
height: 600px;
overflow: visible;
}
.sticky {
position: sticky;
top: 0;
}
当滚动到 .sticky 即将离开 .section 的底部区域时,它会自动“脱粘”而不再吸附。
这也就是说:
sticky 不是全页面范围内固定,而是在其包含块(父元素)范围内固定。
这点与 position: fixed 有本质不同。
四、实际场景推荐:sticky 的用武之地
1. 表头吸顶
表格中的 thead 永远固定在顶部,是 sticky 的经典场景:
thead {
position: sticky;
top: 0;
background: white;
z-index: 10;
}
冷知识提醒:不要忘了加 background 和 z-index,否则会被后面的表格内容遮挡。
2. 左侧目录导航
当你在写文档页面、博客系统、掘金专栏时,目录条跟随滚动吸附。
.nav {
position: sticky;
top: 20px;
}
提示:设置 top: 20px 可以保持一点视觉上的留白感,避免太贴边。
3. 分段标题悬浮
像微信公众号正文那种标题悬浮,每个段落标题随着滚动在顶部短暂停留,也是 sticky 的天然优势。
h2 {
position: sticky;
top: 0;
background: white;
}
.section-title {
scroll-margin-top: 60px;
}
个属性的意思是:在浏览器滚动到锚点时,距离顶部保留 60px 的空隙,刚好与 sticky 的吸顶位置对齐。
六、你应该避免的错误总结
尾声:粘贴的不只是样式,更是理解力
CSS 很多“高级”特性并不是写法复杂,而是对浏览器工作方式的理解不够清晰。position: sticky 看似只是个定位属性,其实牵涉了滚动上下文、布局流、容器模型、层级控制等多个维度。
当你真正理解 sticky 的“粘性边界”与“父级限制”之后,你会发现它比 fixed 更灵活,也更优雅。
下一次当你写 sticky 的时候,不妨回想这篇文章里说的几条冷知识。让你的样式也拥有一点“持久的粘性”。
本文转载于:https://juejin.cn/post/7507073213865689138
如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。