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

相关推荐
Access开发易登软件3 分钟前
Access开发实战:绘制漏斗图实现业务转化分析
数据库·信息可视化·html·vba·图表·access
一行注释7 分钟前
前端数据加密:保护用户数据的第一道防线
前端
running up9 分钟前
Java集合框架之ArrayList与LinkedList详解
javascript·ubuntu·typescript
纪伊路上盛名在12 分钟前
记1次BioPython Entrez模块Elink的debug
前端·数据库·python·debug·工具开发
xiaoxue..14 分钟前
React 之 Hooks
前端·javascript·react.js·面试·前端框架
Alair‎18 分钟前
300TypeScript基础知识
javascript
旧梦吟19 分钟前
脚本网页 三人四字棋
前端·数据库·算法·css3·html5
莫物21 分钟前
element el-table表格 添加唯一标识
前端·javascript·vue.js
我看刑22 分钟前
【已解决】el-table 前端分页多选、跨页全选等
前端·vue·element
我会一直在的28 分钟前
Fiddler基础使用介绍
前端·测试工具·fiddler