使用 css `scroll-snap-type` 和 `scroll-snap-align` 可原生实现全屏视频列表的强制滚动对齐,完美复刻 tiktok/youtube shorts 的“一屏一视频”滑动体验,无需任何 javascript 库或额外脚本。
要打造类似 TikTok 或 YouTube Shorts 的沉浸式垂直视频流——即用户每次滚动都精准停驻在单个全屏视频上,关键在于启用浏览器原生的 CSS 滚动吸附(Scroll Snap) 功能。这完全通过纯 CSS 实现,零 JavaScript 依赖,轻量、高效且兼容性良好(Chrome 69+、Firefox 68+、Safari 11.1+、Edge 79+ 均已支持)。
在 html 元素上启用垂直强制吸附
必须作用于 html(而非 body),因为 scroll-snap-type 在 body 上可能被忽略或失效:
html {
scroll-snap-type: y mandatory; /* y:仅垂直方向吸附;mandatory:强制停靠,禁止悬停在两个元素之间 */
background-color: #090909;
}为每个视频容器设置吸附锚点
.video-box 是每个全屏视频的包裹容器,需指定其吸附对齐方式。start 表示以容器顶部为吸附基准(推荐用于首屏对齐);也可用 center(居中对齐)或 end(底部对齐):
.video-box {
display: flex;
align-items: center;
scroll-snap-align: start; /* 关键:定义该元素作为滚动吸附目标 */
height: 100vh; /* 确保每个容器占满视口高度(强烈建议显式设置) */
scroll-margin-top: 0; /* 可选:微调吸附偏移(如需避开固定导航栏) */
}优化视频样式与行为
保持原有响应式设计,同时补充 height: 100vh 保障容器高度稳定(避免因内容撑开导致吸附错位):
.video-box video {
box-sizing: border-box;
padding: 8px;
margin: 0 auto;
max-height: 100vh;
max-width: 100%;
width: auto; /* 防止横屏视频被压缩失真 */
height: auto;
}
(精简版)TikTok-like Scroll
至此,你已拥有一套简洁、可靠、高性能的 TikTok 式全屏视频滚动方案——全部由 CSS 驱动,开箱即用。