打造丝滑滚动体验:Scroll-driven Animations 正式上线!

🌀 打造丝滑滚动体验:Scroll-driven Animations 正式上线!

🚨 告别 JS 手动监听滚动条,CSS 新能力让你用两行代码实现高级滚动动效。

🔍 什么是 Scroll-driven Animations?

Scroll-driven animations(基于滚动的动画)是 CSS Animation 最新草案的一部分。它允许你直接在 CSS 中根据页面滚动进度驱动动画,无需 JavaScript

由 Chrome 团队推动,目前已在 Chromium 系浏览器中可用(Chrome 115+)。

🎯 为什么值得关注?

传统方式 Scroll-driven Animations
监听 scroll 事件 + 手动计算 ✅ CSS 声明式写法
使用 JS 设置 transform/style ✅ 浏览器原生优化
滚动与动画不同步、卡顿问题 ✅ 完美同步、硬件加速

✅ 性能更好 ✅ 写法更简洁 ✅ 更可组合


🧪 实战示例:滚动时淡入卡片列表

🖼️ 直接先上效果图!

💡 具体

html 复制代码
<!-- HTML -->
<section class="container">
  <div class="card">Card 1</div>
  <div class="card">Card 2</div>
  <div class="card">Card 3</div>
</section>
css 复制代码
// css 

@keyframes fade-in {  
	from { opacity: 0; transform: translateY(30px); }  
	to   { opacity: 1; transform: translateY(0); }
}
.section {  
	animation-name: fade-in;
	// 核心实现部分!
	animation-timeline: view();
	animation-range: entry 0% cover 30%;
	animation-fill-mode: both;
}

.card {
  opacity: 0;
  transform: translateY(40px);
  animation-name: fade-in;
  animation-timeline: view();
  animation-range: entry 0% cover 40%;
  animation-fill-mode: both;
  animation-duration: 1s;
 }

🧠 核心知识点拆解

animation-timeline: view();

绑定当前元素可见区域与滚动相关的时间线。

animation-range

控制动画触发的起始与结束时机:

text 复制代码
entry 0%       // 元素开始进入视口的时刻
cover 30%      // 元素在视口中显示 30% 的时刻

animation-fill-mode: both

确保动画前后状态都保留,避免一闪而过。

🔍 浏览器会根据 .card 元素进入视口的进度,平滑播放动画。

📦 更多时间线类型

cssanimation-timeline: scroll(root block); 用于绑定整个滚动区域(类似 parallax 效果)。 cssanimation-timeline: view(); 用于绑定单个元素进入/离开视口的过程。-

🌐 浏览器兼容性

浏览器 支持情况
✅ Chrome 完整支持(115+)
✅ Edge 支持
🔶 Safari 正在开发中
❌ Firefox 尚未支持

📚 延伸阅读

✨ 总结

Scroll-driven Animations 正式宣告: 滚动动画进入声明式时代 。 你再也不需要手动写 scroll 监听器,也无需用 JS 操作样式。 只需几行 CSS,就能实现视差滚动、延迟加载、进度动画等视觉效果。

赶紧打开 Chrome DevTools 开始尝试吧,下一代动效方案,你准备好了吗?

👍 如果你觉得这篇文章有帮助,欢迎点赞、收藏,让更多人了解 CSS 的新能力!

相关推荐
奶球不是球5 小时前
elementplus组件中el-calendar组件自定义日期单元格内容及样式
javascript·css·css3
我这一生如履薄冰~7 小时前
css属性pointer-events: none
前端·css
苏打水com10 小时前
第十九篇:Day55-57 前端工程化进阶——从“手动低效”到“工程化高效”(对标职场“规模化”需求)
前端·css·vue·html
TE-茶叶蛋11 小时前
html5-qrcode扫码功能
前端·html·html5
2501_9064676311 小时前
HTML5结合Vue3实现百万文件分块上传的思路是什么?
前端·html·html5·vue上传解决方案·vue断点续传·vue分片上传下载·vue分块上传下载
kirinlau11 小时前
vue3+vite+scss项目使用tailwindcss
前端·css·scss
阿贾克斯的黎明11 小时前
现代前端的魔法标签:HTML5 语义化标签全解析
前端·html·html5
composurext13 小时前
录音切片上传
前端·javascript·css
我命由我1234513 小时前
Python Flask 开发:在 Flask 中返回字符串时,浏览器将其作为 HTML 解析
服务器·开发语言·后端·python·flask·html·学习方法