by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11505
本文可全文转载,独立域名个人网站无需授权,但需要保留原作者、出处以及文中链接,任何网站均可摘要聚合,商用请联系授权。
三年前,我有介绍过渐弱动画的媒体查询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手机下查看才有效果。
手机查看的话,需要去手机的设置里,设置减少透明度这个选项。
好吧,就这些,一个与用户体验密切相关的CSS新特性。
不过,按照以往的尿性开看,没几个前端会在真实项目中使用的,投入产出比太低,吃力不讨好。
所以,大家了解下就好了,万一以后有机会开发个很多人使用的UI组件,这个就有用处了,毕竟用的人多,价值就上来了。
感谢阅读,欢迎。
😋😛😝😜
本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11505
(本篇完)