- CSS 教程
- CSS - 教程
- CSS - 简介
- CSS - 语法
- CSS - 选择器
- CSS - 包含
- CSS - 度量单位
- CSS - 颜色
- CSS - 背景
- CSS - 字体
- CSS - 文本
- CSS - 图像
- CSS - 链接
- CSS - 表格
- CSS - 边框
- CSS - border-block 属性
- CSS - 边框内联
- CSS - 边距
- CSS - 列表
- CSS - Padding 属性
- CSS - 光标
- CSS - 轮廓
- CSS - 维度
- CSS - 滚动条
- CSS - 内联块
- CSS - 下拉列表
- CSS - visibility 属性
- CSS - Overflow 属性
- CSS - 清除修复
- CSS - float(浮点)
- CSS - 箭头
- CSS - resize 属性
- CSS - quotes 属性
- CSS - order 属性
- CSS - Position 属性
- CSS - hypens 属性
- CSS - :hover(悬停)
- CSS - display(显示)
- CSS - focus 属性
- CSS - zoom(缩放)
- CSS - translate 属性
- CSS - Height 属性
- CSS - hyphenate-character 属性
- CSS - Width 属性
- CSS - opacity 属性
- CSS - z-index 属性
- CSS - bottom 属性
- CSS - 导航栏
- CSS - 覆盖
- CSS - 表单
- CSS - 对齐
- CSS - 图标
- CSS - 图片库
- CSS - 注释
- CSS - 加载器
- CSS - Atrribute 选择器属性
- CSS - 运算器
- CSS - root
- CSS - 盒子模型
- CSS - 计数器
- CSS - Clip (Obsolete) 属性
- CSS - writing-mode 属性
- CSS - Unicode-bidi 属性
- CSS - min-content 属性
- CSS - 全部
- CSS - inset 属性
- CSS - isolation 属性
- CSS - overscroll-behavior 属性
- CSS - justify-items 属性
- CSS - justify-self 属性
- CSS - tab-size 属性
- CSS - pointer-event 属性
- CSS - place-content 属性
- CSS - place-items 属性
- CSS - place-self 属性
- CSS - max-block-size 属性
- CSS - min-block-size 属性
- CSS - mix-blend-mode 属性
- CSS - max-inline-size 属性
- CSS - min-inline-size 属性
- CSS - offset 属性
- CSS - accent-color 属性
- CSS - user-select 属性
- CSS 高级
- CSS - grid 属性
- CSS - Grid 布局
- CSS - flexbox
- CSS - vertical-align 属性
- css - positioning
- css - layers
- css - pseudo_classes
- CSS - 伪元素
- CSS - @ 规则
- CSS 滤镜 - text-effect 属性
- CSS 分页媒体
- CSS 打印
- CSS - 布局
- CSS - 验证
- CSS - 图像精灵
- CSS - !important
- CSS - 数据类型
- CSS3 教程
- CSS - 圆角
- CSS - 边框图像
- CSS - 多种背景
- CSS - 渐变
- CSS - box-shadow 属性
- CSS - box-decoration-break 属性
- CSS - caret-color 属性
- CSS - text-shadow 属性
- CSS - 2D 转换
- CSS - 3D 变换
- CSS - transition 属性
- CSS - 动画
- CSS - 多列布局
- CSS - 盒子大小调整
- CSS - 工具提示
- CSS - buttons
- CSS - 分页
- CSS - 变量
- CSS - 媒体查询
- CSS - 值函数
- CSS - 数学函数
- CSS - Mask 属性
- CSS - shape-outside 属性
- CSS - 样式图像
- CSS - 特异性
- CSS - 自定义属性
- CSS 响应式
- CSS - 响应式网页设计 (RWD)
- CSS - 响应式设计视口
- CSS - 响应式网格视图
- CSS - 响应式媒体查询
- CSS - 响应式图像
- CSS - 响应式视频
- CSS - 响应式框架
- CSS 引用
- CSS - 所有属性列表
- CSS - 颜色引用
- CSS - 浏览器支持参考
- CSS - 网页字体
- CSS 工具
- CSS - PX 到 EM 的转换
CSS 媒体功能 - prefers-reduced-motion
CSS 媒体功能 prefers-reduced-motion 允许检查用户是否在其设备上启用了设置以减少不必要的动画。此设置通知设备的浏览器,用户已选择一个界面,该界面会删除、最小化或替换运动驱动的动画。
可能的值
- no-preference − 此值表示用户未在其设备上指示任何特定偏好。关键字值被视为 false。
- reduce − 此值表示用户已在其设备上激活了 reduce motion 设置。关键字值被视为 true。
语法
prefers-reduced-motion: no-preference|reduce;
CSS prefers-reduced-motion - 示例
如果打开了“减弱动态效果”设置,则此页面上的绿色框将移动得更慢、更顺畅,背景将变为粉红色,文本下方将有一行。如果您没有打开“减弱动态效果”设置,则绿色框将正常移动,背景将保持绿色。
- 脉冲 − 此动画使元素每四秒脉冲一次。
- 溶解 - 此动画使元素每两秒淡入和淡出一次。
按照链接上的步骤模拟 prefers-reduced-motion 模式并测试以下示例。
这是一个例子 -
<html>
<head>
<style>
.box {
animation: pulse 4s linear;
background-color: green;
color: white;
width: 160px;
padding: 10px;
border-radius: 5px;
}
@media (prefers-reduced-motion) {
.box {
animation: dissolve 2s linear;
background-color: pink;
text-decoration: overline;
}
}
@keyframes pulse {
0% {
transform: scale(0.5);
}
50% {
transform: scale(0.8);
}
100% {
transform: scale(08.);
}
}
@keyframes dissolve {
0% {
opacity: 0.7;
}
50% {
opacity: 0.5;
}
100% {
opacity: 0.7;
}
}
</style>
</head>
<body>
<div class="box">
prefers-reduced-motion
</div>
</body>
</html>
CSS prefers-reduced-motion - 无偏好值
带有 (prefers-reduced-motion: no-prefernce) 的@media查询将为喜欢减少运动的用户禁用动画 (盒子将保持静止)。
这是一个例子 -
<html>
<head>
<style>
.box {
width: 220px;
height: 100px;
background-color: violet;
animation: moveRight 2s linear infinite;
}
@keyframes moveRight {
0% {
transform: translateX(0);
}
100% {
transform: translateX(100%);
}
}
@media (prefers-reduced-motion: no-preference) {
.box {
animation: none;
transform: none;
}
}
</style>
</head>
<body>
<div class="container">
<div class="box">prefers-reduced-motion: no-preference</div>
</div>
</body>
</html>
CSS prefers-reduced-motion - reduce 值
使用 (prefers-reduced-motion: reduce) 的@media查询检查用户对减少运动的偏好。如果用户在其设备上启用了减少运动设置,则盒子将在连续循环中从左到右水平移动。
这是一个例子 -
<html>
<head>
<style>
.box {
width: 220px;
height: 100px;
background-color: violet;
animation: moveRight 2s linear infinite;
}
@keyframes moveRight {
0% {
transform: translateX(0);
}
100% {
transform: translateX(100%);
}
}
@media (prefers-reduced-motion: reduce) {
.box {
animation: none;
}
}
</style>
</head>
<body>
<div class="container">
<div class="box">prefers-reduced-motion: reduce</div>
</div>
</body>
</html>
下表显示了如何在不同操作系统的 Firefox 中启用减少运动功能:
操作系统 | 如何在Firefox中启用减少运动 |
---|---|
GTK/GNOME | 设置>辅助功能>查看>减少动画 |
Older versions of GNOME | GNOME 调整 > 常规选项卡(或外观,取决于版本) > 动画 |
Plasma/KDE | 系统设置 > 工作区行为 -> 常规行为 > “动画速度”设置为“即时” |
Windows 10 | 在 Windows 中>显示动画>易用性设置> |
Windows 11 | 动画效果>视觉效果>辅助功能设置> |
macOS | “系统偏好设置”>“辅助功能”>“显示”>“减弱动态效果” |
iOS | Motion >辅助功能>设置 |
Android 9+ | >辅助功能>删除动画的设置 |
Firefox about:config | 添加一个名为 ui.prefersReducedMotion 的数字首选项,并将其值设置为 0 表示完整动画,或将其值设置为 1 以指示减少运动的首选项。. |