transition加了没反应是因为仅对可计算可插值属性(如opacity、transform)生效,且必须在初始状态声明、触发实际值变化;display、height:auto等不可插值属性不支持过渡,伪类中写transition或漏设起止值也会失效。
transition 不是“加了就能动”,它只响应可计算的属性值变化,且必须有明确的触发时机和合法的起止状态。
常见错误现象包括:鼠标悬停没变化、JS 切 class 后动画一闪而过、或干脆完全不动。
display、z-index、font-family 等,浏览器不支持插值计算.box:hover { opacity: 0; },但没在基础样式里设 opacity: 1,浏览器可能取默认值或继承值,导致过渡失效style.opacity 后立刻改回,中间没让浏览器有机会识别状态差;需用 void element.offsetWidth 强制同步布局transform 或 will-change 却没配 contain: layout paint,导致子元素 transition 被截断(尤其在 iOS Safari)写太宽会拖慢性能,写太窄又漏掉关键变化。核心原则:只过渡能 GPU 加速、不影响布局的属性。
transform 和 opacity,它们不触发重排,浏览器自动走合成层width、height、margin、padding —— 改它们会触发重排,动画卡顿明显all,它会把 color、border-color、font-size 全部拉进来,一次 hover 可能意外过渡十几个属性max-height 替代 height,并设初始值为 0、结束值为足够大的像素数(如 500px),同时加 overflow: hidden
时长不是越长越好,缓动也不是 ease 万能。真实交互中,人眼对 200ms 内的变化最敏感,超过 300ms 就容易感知延迟。
立即学习“前端免费学习笔记(深入)”;
0.15s – 0.25s,搭配 cubic-bezier(0.4, 0, 0.2, 1)(即 ease-in-out 的增强版)0.3s – 0.4s,起始加一点延迟(transition-delay: 0.05s)可提升节奏感linear 用于交互类动画——它缺乏加速/减速,看起来像机械滑动transition: opacity 0.25s ease, transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94)
直接操作 element.style 很容易让 transition 失效,尤其在单页应用中替换内容时。
setTimeout 硬等时间移 class——系统动画缩放、GPU 未就绪、CSS 覆盖都会导致偏差transitionend 时,务必校验 e.target === element 和 e.propertyName,否则子元素冒泡会误触发element.offsetHeight 强制重排,再设目标样式transform 过渡更敏感,建议加 will-change: transform 和 backface-visibility: hidden 提前升层真正难的不是写对一行 transition,而是判断某个交互是否适合用它——状态是否只有两个、变化是否可预测、属性是否可硬件加速。一旦条件不满足,就得切到 @keyframes 或 requestAnimationFrame。