0

0

CSS滚动触发动画基础_配合Intersection Observer的实践

P粉602998670

P粉602998670

发布时间:2026-02-24 09:51:37

|

783人浏览过

|

来源于php中文网

原创

intersection observer 实现滚动动画的最小可行写法是:元素挂载后立即创建 observer,配置 rootmargin(如"0px 0px -100px 0px"兼容旧 safari)和 threshold 数组,回调中仅对 isintersecting 为 true 的 entry 添加含 animation-fill-mode: forwards 的动画类,并立即 unobserve。

css滚动触发动画基础_配合intersection observer的实践

Intersection Observer 触发滚动动画的最小可行写法

直接用 IntersectionObserver 监听元素进入视口,比监听 window.onscroll 更轻量、更可靠——它不随滚动频繁触发,也不受节流误判影响。

常见错误是等 DOM 渲染完才初始化 Observer,结果首屏元素没被观测到;或者漏掉 rootMargin,导致动画在元素刚露头时就执行,用户根本看不到过渡过程。

  • 必须在元素挂载后(如 document.querySelectorAll(".anim-trigger") 有结果)再创建 Observer
  • rootMargin: "0px 0px -20% 0px" 是常用值:让动画提前在元素还有 20% 高度未进入视口时启动,避免“闪入”
  • 回调中对每个 entry 要检查 entry.isIntersecting,否则元素移出视口时也会触发(可能造成重复动画)
const observer = new IntersectionObserver((entries) => {
  entries.forEach(entry => {
    if (entry.isIntersecting) {
      entry.target.classList.add("animate-in");
      observer.unobserve(entry.target); // 动画只执行一次
    }
  });
}, { rootMargin: "0px 0px -20% 0px" });
<p>document.querySelectorAll(".anim-trigger").forEach(el => observer.observe(el));

CSS 动画类名要配 animation-fill-mode: forwards

否则动画播完立刻回退到初始状态,比如 translateY(0) → translateY(20px) 播完又弹回 0,视觉上就是“动一下又消失”。

立即学习前端免费学习笔记(深入)”;

另一个坑是把 opacity 和位移动画写在同一个 @keyframes 里但没设起始透明度,导致元素默认 opacity: 0 却没隐藏,布局占位异常。

YouWare
YouWare

社区型AI编程平台,支持一键部署和托管

下载
  • 动画类必须含 animation-fill-mode: forwards
  • 若用 opacity,初始状态得显式设为 opacity: 0,且确保父容器没强制撑高
  • 避免在动画中改 heightdisplay,会触发重排,卡顿明显
.animate-in {
  opacity: 0;
  transform: translateY(30px);
  animation: slideIn 0.6s ease-out forwards;
}
@keyframes slideIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

兼容性兜底:Safari 15.4 以下不支持 rootMargin 百分比值

Safari ≤15.4 会直接忽略 rootMargin: "-20%",退化成 "0px",导致动画触发太晚甚至不触发。这不是 bug,是规范早期实现差异。

不能靠 UA 判断,因为 iOS WebView 行为也不一致;稳妥做法是用像素值替代,或加一层 JS 计算。

  • 最简方案:把 rootMargin 改成 "0px 0px -100px 0px"(假设平均设备视口高度约 500px,-20% ≈ -100px)
  • 进阶方案:用 window.innerHeight * 0.2 动态算像素值,再拼字符串传给 rootMargin
  • 不推荐 fallback 到 scroll 监听——性能和体验差距太大,真要兼容老 Safari 就老实做降级动画(如无位移,只淡入)

多个动画顺序错乱?别依赖 DOM 顺序,用 threshold 分层控制

当一页有十几个动效元素,按 DOM 顺序 observe 后,它们几乎同时触发,看不出逐个浮现的节奏感。想实现“从上到下依次入场”,靠 CSS animation-delay 不稳定(JS 添加 class 时间不可控),也不该手动 setTimeout。

真正可控的方式是用 threshold 数组,让不同区域的元素在不同相交比例时触发。

  • 例如:首屏大图设 threshold: [0.1](10% 进入即动),正文段落设 threshold: [0.3],底部按钮设 threshold: [0.6]
  • 每个元素可单独 new Observer,或用一个 Observer + entry.intersectionRatio 做条件分支
  • 注意 threshold 是数组,不是单个数字,写成 [0.3] 而非 0.3(后者会被忽略)

CSS 滚动动画的复杂点不在 JS 或 CSS 单独哪一块,而在于三者咬合:Observer 的触发时机、CSS 动画的起始状态、以及不同设备视口尺寸对 rootMargin 的实际影响。少盯住其中一环,效果就容易断层。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1558

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

642

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1027

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

980

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

186

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

89

2025.08.07

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1226

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

CSS教程
CSS教程

共754课时 | 35.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号