一个新的CSS媒体查询prefers-reduced-transparency

这篇文章发布于 2025年01月2日,星期四,23:46,归类于 CSS相关。 阅读 798 次, 今日 5 次 没有评论

 

media与用户体验

一、为故而知新

三年前,我有介绍过渐弱动画的媒体查询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选项卡面板,如果没有,参照下图示意打开:

Chrome开发者工具渲染选项卡

其中就有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还是红灿灿的一片。

prefers-reduced-transparency兼容性截图

所以,目前,上面的demo演示页面只能在Chrome,或者版本比较高的Android手机下查看才有效果。

手机查看的话,需要去手机的设置里,设置减少透明度这个选项。

  • In Windows 10/11: Settings > Personalization > Colors > Transparency effects.
  • In macOS: 系统设置 > 无障碍访问 > 显示 > 减少透明度
  • In iOS: 设置 > 无障碍访问 > 显示 & 文本尺寸 > 减少透明度

好吧,就这些,一个与用户体验密切相关的CSS新特性。

不过,按照以往的尿性开看,没几个前端会在真实项目中使用的,投入产出比太低,吃力不讨好。

所以,大家了解下就好了,万一以后有机会开发个很多人使用的UI组件,这个就有用处了,毕竟用的人多,价值就上来了。

感谢阅读,欢迎

😋😛😝😜

(本篇完)

分享到:


发表评论(目前没有评论)