opacity过渡需显式声明transition: opacity而非all,配合visibility或pointer-events防误点,避免display:none,禁用rgba替代,仅修改opacity和transform以保性能。
直接写 transition: all 0.3s 不一定能触发 opacity 渐变,尤其在元素初始状态为 opacity: 0 且未渲染时。浏览器可能跳过过渡,直接显示最终值。
transition: opacity 0.3s ease,避免依赖 all
opacity 值(不能靠继承或未定义)display: none 控制显隐,transition 完全失效——改用 visibility 或控制 opacity + pointer-events
opacity: 0 的元素仍占据布局空间、响应点击事件。单纯渐隐后用户可能点到“看不见但存在”的元素上。
visibility: hidden;淡入开始前先设为 visibility: visible
pointer-events: none 配合 opacity 动画,例如:button {
opacity: 0;
pointer-events: none;
transition: opacity 0.2s, pointer-events 0s 0.2s;
}
button.show {
opacity: 1;
pointer-events: auto;
transition: opacity 0.2s, pointer-events 0s;

}
虽然 background-color: rgba(0,0,0,0.5) 和 opacity: 0.5 视觉相似,但行为完全不同:
opacity 影响整个元素及其子树,支持过渡,且会继承父级透明度叠加rgba() 只影响当前属性,过渡只改变颜色通道,无法实现子元素整体淡入淡出opacity 是 CSS 合成属性(compositing property),理论上只触发重绘(repaint),性能好。但如果同时修改了 width、height、top 等布局属性,就会强制重排,导致掉帧。
opacity 和 transform(如 translateY)这类可被 GPU 加速的属性will-change: opacity 提示浏览器提前优化,但仅在复杂场景下启用,避免滥用