

新闻资讯
技术学院使用 css 原生 scroll-snap 属性即可实现类似 tiktok/youtube shorts 的全屏视频垂直滚动与精准吸附效果,无需 javascript;关键在于为 `html` 元素设置 `scroll-snap-type: y mandatory`,并为每个视频容器添加 `scroll-snap-align: start`。
要打造真正“TikTok-like”的垂直视频流体验——即用户滚动时,视口自动对齐并锁定到单个完整视频区域(而非停留在两个视频之间),CSS 提供了专为此类交互设计的原生解决方案:Scroll Snap API。它完全基于纯 CSS,零 JavaScript 依赖,轻量、高性能且语义清晰。
核心配置仅需两步:
在滚动容器上启用滚动吸附行为
必须作用于实际发生滚动的容器。在标准文档流中,body 默认不触发滚动(滚动发生在 html 根元素),因此务必将 scroll-snap-type
应用于 html 元素(而非 body):
html {
scroll-snap-type: y mandatory;
background-color: #090909;
}为每个视频区块定义吸附锚点
给每个 .video-box 添加 scroll-snap-align,指定其哪一部分与视口对齐:
.video-box {
display: flex;
align-items: center;
scroll-snap-align: start; /* 视口顶部与 .video-box 顶部对齐 */
height: 100vh; /* 关键!确保每个区块占满视口高度 */
scroll-margin-top: 0; /* 可选:微调吸附偏移(如需顶部留白) */
}✅ 注意:.video-box 必须具有明确的高度(如 100vh),否则吸附位置无法准确计算。原代码中缺失该声明,需补全。
完整优化后的
? 注意事项与增强建议:
至此,你的视频列表便拥有了原生、丝滑、无 JS 的 TikTok 式滚动体验——简洁、可靠,且符合现代 Web 最佳实践。