iOS低电量模式强制启用prefers-reduced-motion: reduce,Safari直接忽略所有CSS动画(含@keyframes、transition、will-change),无法绕过;需用DevTools模拟验证,显式重置transition为none、补终态样式、移除will-change,并监听change事件动态切换class。
因为低电量模式会强制启用系统级的 prefers-reduced-motion: reduce,Safari 直接忽略所有 CSS 动画,包括 @keyframes、transition 和 will-change 触发的硬件加速效果——这不是 Bug,而是 iOS/iPadOS 的硬性限制,无法通过代码绕过。
页面滚动变卡顿、加载指示器(如旋转图标)停止转动、折叠/淡入等交互无过渡效果、按钮点击后状态切换突兀。这些不是网页写错了,而是 Safari 在底层直接跳过了动画渲染流程。
别靠猜,用 DevTools 快速验证:
window.matchMedia('(prefers-reduced-motion: reduce)').matches 是否返回 true
animation: none 不够很多人只在媒体查询里写 animation: none,但忽略了其他关键点:
transition: all 0.3s 这类声明即使不执行动画,仍保留在样式计算中,导致 transitionend 事件永不触发transition: none,不能留空、注释掉,也不能写成 transition: none 0s
animation: spin 2s infinite 需配 transform: rotate(0),否则降级后元素可能卡在中间角度will-change: transform 在 reduce 下不仅无效,还可能引发渲染异常,建议一并移除如果你用 JS 控制动效组件(比如手风琴菜单、模态框),不能只在初始化时判断一次 matchMedia 结果:
motionQuery.addEventListener('change', handler)(Safari 14+)或旧版的 addListener
<html> 添加 reduced-motion class,CSS 层统一接管开关,JS 只负责切换 classtransition={{ duration: 0 }} 或传 disable: m