一、为故而知新
三年前,我有介绍过渐弱动画的媒体查询prefers-reduced-motion
,参见文章"你不知道的CSS media查询与用户体验"的第5小节。
使用示意:
@media (prefers-reduced-motion: reduce) {
/* ⽤户希望减弱动画 */
}
目前Chrome浏览器新支持了一个名为prefers-reduced-transparency
的媒体查询,其设计初衷和使用背景与上面提到的prefers-reduced-motion
类似。
是这样的:
- 在设备层面,不透明界面会增加渲染绘制的开销,在移动设备上会加速电量的流失。
- 在用户层面,对于少部分用户,不透明界面会导致头痛,或者因为各种类型的视力缺陷而造成视觉障碍。
此时,用户就会考虑关闭操作系统的半透明设置选项。
二、如何使用降低透明度
目前,Windows、macOS 和 iOS 都提供了系统偏好设置,可降低或移除界面的透明度。
例如,在我的Windows 10操作系统下,在显示设置里,就有这么个开关选项,如下截图所示:
而prefers-reduced-transparency
的媒体查询就是为这种场景设计的。
使用示意:
.overlay {
--opacity: .5;
background: rgba(0 0 0 / var(--opacity));
@media (prefers-reduced-transparency: reduce) {
--opacity: .95;
}
}
不过实际开发并不需要我们去系统层面进行自定义设置,Chrome的开发者工具就提供了相关的选项。
操作路径如下截图所示,首先,开启Rendering选项卡面板,如果没有,参照下图示意打开:
其中就有prefers-reduced-transparency:reduce
的下拉选项,截图如下:
此时,我们就可以针对性地进行用户体验方面的处理的。
三、使用案例
我们通过一个简单的案例,开看一下prefers-reduced-transparency:reduce
的执行效果。
点击按钮,显示模态对话框(浏览器原生的能力),然后通过CSS代码以及媒体查询,控制模态背景的半透明度,相关的HTML和CSS代码如下所示:
<button
onClick="dialog.showModal();"
>点击我</button>
<dialog
id="dialog"
onclick="this.close()"
>我是模态框,看看背景的半透明是多少?</dialog>
dialog::backdrop {
--opacity: .5;
background: rgba(0 0 0 / var(--opacity));
@media (prefers-reduced-transparency: reduce) {
--opacity: .95;
}
}
在默认情况下,我们点击按钮,模态框的背景半透明度,大致是下图这般模样:
黑色半透明背景后面的文字和图形可谓是清晰可见。
当我们,Chrome控制台Rendering选项卡开启prefers-reduced-transparency:reduce
选项后,会发现,背景一下子变得好黑,比包拯还黑。
这种渲染对于有视力障碍的人来说,就会舒服很多。
眼见为实,您可以狠狠地点击这里:CSS prefers-reduced-transparency与模态半透明颜色demo
四、兼容性、结语等
来看下此@media媒体查询语句的兼容性,如下图所示,可以看到Chrome 118开始支持,而Firefox(实验支持)和Safari还是红灿灿的一片。
所以,目前,上面的demo演示页面只能在Chrome,或者版本比较高的Android手机下查看才有效果。
手机查看的话,需要去手机的设置里,设置减少透明度这个选项。
- In Windows 10/11: Settings > Personalization > Colors > Transparency effects.
- In macOS: 系统设置 > 无障碍访问 > 显示 > 减少透明度
- In iOS: 设置 > 无障碍访问 > 显示 & 文本尺寸 > 减少透明度
好吧,就这些,一个与用户体验密切相关的CSS新特性。
不过,按照以往的尿性开看,没几个前端会在真实项目中使用的,投入产出比太低,吃力不讨好。
所以,大家了解下就好了,万一以后有机会开发个很多人使用的UI组件,这个就有用处了,毕竟用的人多,价值就上来了。
感谢阅读,欢迎分享。
😋😛😝😜
(本篇完)