打造丝滑滚动体验: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 的新能力!

相关推荐
芝士加9 分钟前
Playwright vs MidScene:自动化工具“双雄”谁更适合你?
前端·javascript
Carlos_sam1 小时前
OpenLayers:封装一个自定义罗盘控件
前端·javascript
前端南玖1 小时前
深入Vue3响应式:手写实现reactive与ref
前端·javascript·vue.js
wordbaby2 小时前
React Router 双重加载器机制:服务端 loader 与客户端 clientLoader 完整解析
前端·react.js
itslife2 小时前
Fiber 架构
前端·react.js
3Katrina2 小时前
妈妈再也不用担心我的课设了---Vibe Coding帮你实现期末课设!
前端·后端·设计
hubber2 小时前
一次 SPA 架构下的性能优化实践
前端
markyankee1012 小时前
HTML基础标签完全指南:新手快速入门,老手夯实基础
html
可乐只喝可乐3 小时前
从0到1构建一个Agent智能体
前端·typescript·agent
Muxxi3 小时前
shopify模板开发
前端