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

相关推荐
一只小风华~1 小时前
CSS aspect-ratio 属性
前端·css
小小愿望2 小时前
解锁前端新技能:让JavaScript与CSS变量共舞
前端·javascript·css
胡西风_foxww3 小时前
CSS 多列布局(Multi-column Layout):快速上手指南
css·column·入门·指南·layout·多列布局·上手
鴆川傲3 小时前
web前端第二次作业
前端·javascript·css
前端老鹰3 小时前
HTML <link rel=“preload“>:提前加载关键资源的性能优化利器
前端·性能优化·html
AliciaIr3 小时前
深入理解CSS居中:面试必备的布局技巧与底层原理(下)
前端·css
胡gh3 小时前
面试官问你如何实现居中?别慌,这里可有的是东西bb
前端·css·面试
EndingCoder4 小时前
Chrome插件开发实战:从零开发高效Chrome插件,提升浏览器生产力
前端·chrome
白云~️5 小时前
html img标签设置默认图片,防止图片路径不存在导致图片不展示影响页面美观
java·前端·html
xixixin_5 小时前
【HTML】在页面中画一条0.5px的线
前端·css·uni-app·html·css3