测试 Web 设计颜色对比度

简要介绍了用于测试和验证设计的无障碍色彩对比度的三种工具和方法。

假设您在浅色背景上有一些文本,如下所示:

系统会显示“The quick brown fox jumps over the lazy dog again”这个词组,其中每个字词或两个字词的颜色都较浅。每个逐渐淡化的字词部分上方显示的是其对比度得分。由于对比度较低,最后几个字非常难以辨认。

虽然您可能可以读懂所有示例,但其他人可能不行。

易辨认的色彩对比度是一种做法,可确保所有人都能轻松阅读文本。有时测试对比度很容易,有时很难。在本文结束时,您将掌握三种新的工具和技术,用于检查、更正和验证 Web 设计对比度,以便应对最棘手的情况。

WCAG 和颜色对比度

W3C 的 Web Accessibility Initiative 提供了相关策略、标准和资源,以确保尽可能多的人能够访问互联网。这些标准的依据是《Web 内容无障碍指南》(WCAG)。最新的稳定版本 WCAG 2.1 涵盖了一项重要的无障碍功能要求:最小对比度

WCAG 2.1 中,两种颜色之间的关系通过对比度来描述,即比较两种颜色的亮度时得到的数字。亮度是一种描述颜色与黑色 (0%) 或白色 (100%) 的接近程度的方式。WCAG 定义了一些规则和计算算法,规定了网站的对比度需要达到什么水平才能实现无障碍。不过,此计算存在已知问题。最终,我们会采用更可靠的方法,但目前,WCAG 是我们能找到的最佳方法。

规则是什么?

AA AAA
正文(小于 24 像素) 4.5 7
大号文本(大于 24 像素) 3 4.5
界面(图标、图表等) 3 未定义

对比度越高,得分就越高,例如 4.5 或 7 而不是 3。如需更熟悉评分表,请查看 Polypane 的对比度检查工具

文本显示在紫色上:一种组合是黑色文本在紫色上,另一种组合是白色文本在紫色上。
您认为哪个配色对比度更强?

测试颜色之间的对比度

现在,我们已经知道要找什么了,接下来该如何测试呢?以下三个免费工具可帮助您检查、校正和衡量网站的对比度。我们将概述每种方法的优点和缺点,以便您能够通过多种方式自信地测试网站颜色和内容的无障碍性。

  1. Pika
    这款 MacOS 应用具有独特的功能,能够显示整个屏幕上的任何颜色、渐变色的颜色、透明颜色等的对比度。intent 是显式的,用户手动选择要比较的像素。自动化程度略低,但功能增益巨大。
  2. VisBug
    这是一个跨浏览器扩展程序,具有独特的功能,能够同时显示多个对比度叠加层,但与开发者工具一样,有时无法检测 intent。
  3. Chrome 开发者工具
    开发者工具内置于 Chrome 中,提供了多种检查、更正和调试颜色问题的方法,但在检查渐变色和半透明颜色时存在缺点,有时无法检测 intent。

Pika(macOS 应用)

如果开发者工具或 VisBug 无法正确评估对比度(例如,当您需要在浏览器之外测试颜色,或者涉及透明度或渐变时),则 Pika 可以帮到您。Pika 是系统工具而非 Web 工具,因此可以访问屏幕上的每个像素。

下载 Pika

这也意味着,使用 Pika 的用户体验与使用 DevTools 或 VisBug 不同。开发者工具和 VisBug 会尽力显示浏览器 DOM 中的文本和背景颜色,而 Pika 比较的颜色是从屏幕上的任意位置手动选择的。这让 Pika 能够获得更大的控制权,并开辟了一些额外的用例:

  • 比较任意两种颜色,无论它们是否在浏览器中,只要您能在屏幕上看到,就可以进行测试。
  • 比较颜色与透明度。
  • 比较渐变中的颜色。
  • 比较使用混合模式(例如 CSS 中的 mix-blend-mode)的颜色。

比较任意两种颜色

将文本与背景颜色进行比较:

并排比较两种灰色,对比度为 13.01,并且符合 AA 和 AAA 目标。

比较矢量图形的描边颜色和填充颜色:

将两个紫色与双色调图标进行比较,它们的对比度为 1.63,并且没有通过任何 WCAG 目标。

比较颜色与透明度

将文本颜色与各种背景示例像素进行比较。在这里,磨砂玻璃效果中最浅的灰色用作背景比较颜色。

在带有模糊半透明字幕的图片中,比较了两种看起来像灰色但实际上是饱和度很低的紫色,它们的对比度为 4.65,符合 AA 目标要求。

比较颜色与渐变

比较在渐变色或图片上的文字。下面将“Lasso”中的 L 与图片的浅蓝色进行比较:

电视节目的屏幕截图,顶部显示节目名称,L 为白色,后面的蓝色进行对比。它们的对比度为 8,并且通过了 AA 和 AAA 目标。

VisBug

VisBug 是一款受 FireBug 启发的工具,可供设计师和开发者直观地检查、调试和玩弄其网站设计。它旨在通过模仿人们熟悉且喜爱的设计工具的界面和用户体验,降低与 Chrome 开发者工具相比的使用门槛。

试用 VisBug,或在 ChromeFirefoxEdgeBraveSafari 中安装。

其中提供的一款工具是无障碍检查工具。

空白页左侧的 VisBug 工具栏的屏幕截图,其中无障碍功能工具图标为粉色,并且显示了一个用于提供该工具说明的弹出式窗口。

跨浏览器(甚至在移动设备上)进行检查

点击“无障碍功能检查”工具后,系统会在提示中报告用户指向或键盘导航到的任何内容的无障碍功能信息。此提示包含发现的前景色和背景色之间的颜色对比。

显示了一个带有标题和图标的组件,周围有一个粉色边界框,VisBug 无障碍功能提示指向粉色框,其中包含文本颜色及其背景的颜色对比报告。该比率为 13.86,同时满足 AA 和 AAA 目标。

检查一个或多个

开发者工具可以查看单个配色方案,也可以生成网页中所有配色方案的报告,但 VisBug 提供了一个不错的中间方案,即允许使用多个配色方案。点击某个元素后,提示将保持不变。按住 Shift 键,然后继续点击其他元素,所有提示都会保持不变:

网页上的链接列表显示了多个 VisBug 无障碍功能叠加层,每个叠加层都会在上下文中指向并报告发现的文本和背景颜色对比度。

对于基于组件的设计,这一点尤为重要,因为组件的多个部分都需要通过对比度得分。这种方法可让您一次性查看所有这些组件部分。也非常适合进行设计审核。

Chrome DevTools

如果您已安装 Chrome,则已经拥有许多对比度测试工具:

Chrome DevTools 颜色选择器

在“元素”面板的 Chrome 开发者工具“样式”窗格中,颜色值旁边会显示一个小方形颜色样本。点击此色块后,您会看到颜色选择器工具。如果可能,工具中间会显示颜色与前景或背景的对比度。

在以下示例中,系统会为自定义属性颜色值打开颜色选择器。对比度得分报告为 15.79,并带有两个绿色对勾标记,表示得分符合 AA 和 AAA WCAG 2.1 要求:

一张屏幕截图,显示了“DevTools Elements”面板,其中“Styles”中显示了颜色选择器,中间显示了颜色的对比度为 4.98。

颜色选择器自动更正

在选择颜色时查看得分很方便,但 Chrome 开发者工具还有一项自动更正功能。当颜色选择器报告无障碍色彩对比度得分未达到要求时,您可以展开该选择器,查看 AA 和 AAA 得分目标值,以及眼睛滴管工具。AA 和 AAA 旁边是色样和一个刷新图标,点击该图标即可找到最接近的合格颜色:

如果您对颜色不挑剔,自动校正功能非常适合您,既能满足无障碍指南的要求,又能轻松完成任务。

检查提示

元素选择工具在页面悬停期间具有一项特殊功能,可报告常规字体、颜色和无障碍信息。元素选择工具是下方屏幕截图中左侧的图标。它是一个带有箭头光标的框,位于右下角。您也可以使用热键 Control+Shift+C(在 macOS 上为 Command+Shift+C)进行选择。

调用元素选择工具的 DevTools 中的方框和箭头图标的屏幕截图。

启用后,该图标会变为蓝色,并且将鼠标指向网页中的任何内容都会显示以下快速检查提示:

与 VisBug 非常相似的叠加层的屏幕截图,其中显示了一些样式信息和一个无障碍部分,该部分显示了对比度得分为 15.79,已达到 AA 目标。

与颜色选择器工具(需要您在“样式”窗格中查找颜色样条)不同,此工具让您只需在页面上指向相应位置即可查看对比度得分。与颜色选择器一样,它一次只能显示一个对比度得分。

Bump bump 'til you pass 🎶?

我经常使用此快速检查工具检查配色,发现它只差一点就达到了所需的比例。我很挑剔,因此不会使用颜色选择器的自动更正功能,而是在 CSS 中调整颜色通道,并观察直到达到所需的比例。我将此过程称为“不断调整,直到通过”,因为我会不断调整颜色通道编号,直到它们通过 WCAG 2.1 为止。

具体步骤如下,且必须按顺序执行:

  1. 在“样式”面板中将键盘焦点设置在颜色上。
  2. 使用键盘快捷键 Control+Shift+C(在 macOS 上为 Command+Shift+C)激活“检查元素”工具。
  3. 将光标指向目标。
  4. 按键盘上的向上/向下键可更改颜色值中的数字。

之所以能这样,是因为 CSS 样式值仍然拥有键盘焦点,而鼠标则可让您将光标指向目标。请务必不要点击目标值,否则焦点将从颜色值区域移开,并且在重新聚焦之前,您将无法再调整值。

CSS 概览

到目前为止,Chrome 开发者工具提供了一次查看一对颜色的方法,但 CSS 概览可以抓取整个网页,并一次显示所有无法访问的配色方案:

运行 CSS 概览捕获工具后,概览摘要的屏幕截图。其中显示了 7 个问题,包括发现的颜色搭配及其不合格结果。

如需详细了解此功能,请参阅这篇博文:CSS 概览:发掘潜在的 CSS 改进机会,或观看 YouTube 上 Jecelyn Yeen 的“开发者工具提示”系列视频,了解如何使用“CSS 概览”面板发掘潜在的 CSS 改进机会

灯塔

Lighthouse 是 Chrome 开发者工具中的另一种审核工具。它可以抓取您的网页并报告无法访问的颜色搭配。其中包含每个配色方案的小屏幕截图,供您查看通过和失败的结果。任何失败的组合都会对您的 Lighthouse 得分产生负面影响。

这些结果可能如下所示:

Lighthouse 评估的屏幕截图,显示了 2 个字词的颜色组合导致文本对比度较低的结果。

JS 控制台

以上所列的所有工具可能都不在您所在的位置。您所在的位置(全天)可能是 JavaScript。您可以试试以下实验。在您构建应用时,控制台的“问题”窗格会不断报告任何色彩对比度无障碍功能问题。在“设置”>“实验”中启用此功能,如下所示:

已启用复选框的屏幕截图:“通过‘问题’面板启用自动对比度问题报告”。

然后,打开“问题”窗格,看看系统是否发现了任何问题。如果存在,它们可能如下所示:

控制台内“问题”面板的屏幕截图,其中报告了 6 个与对比度有关的错误。

色盲模拟

在讨论颜色对比度和确保颜色搭配易于访问时,值得指出的是视觉缺陷模拟工具。这会更改设计的颜色或外观,以演示不同类型色盲的结果,让您有机会修改设计,使颜色不再是用户体验与用户沟通的唯一方式。

模拟开发者工具中用于模拟视觉缺陷的选项的屏幕截图:无模拟、视力模糊、红色盲、绿色盲、蓝色盲、全色盲。

仅使用颜色来描述信息(例如红色表示不好,绿色表示好)并不是安全的无障碍功能做法。有些人看到的绿色或红色不一样,此模拟工具可帮助您体验并记住这一点。

颜色对比度系统偏好设置模拟

越来越多的用户会更改操作系统中的对比度设置,以便在界面中请求更低或更高的对比度个性化设置。CSS 可以利用此设置,就像它可以利用浅色或深色主题偏好设置一样。Chrome 开发者工具提供此偏好设置的模拟功能,因此设计可以进行测试并根据用户请求进行调整,而无需从系统中切换设置。

模拟开发者工具中用于模拟 CSS 媒体查询 prefers-contrast 的选项的屏幕截图:无模拟、更多、更少、自定义。

试用 WCAG 3.0 APCA

您还可以尝试使用实验性 APCA 颜色比率评分系统测试颜色搭配。您可以通过“设置”>“实验”启用此功能,它会将 WCAG 2.1 比率系统替换为更新且经过改进的对比度检查器算法,让您在该提案朝着标准迈进的过程中预览结果。

已启用复选框的屏幕截图:“启用新的高级感知对比度算法 (APCA),取代之前的对比度和 AA/AAA 准则。”

启用后,您可以使用点检查提示或颜色选择器查看配色得分,并确定其是否通过:

开发者工具“检查元素”工具提示针对 dd 元素显示的对比度得分为 -100.2%。

总结

色彩对比度是实现网站无障碍功能的重要因素,遵循这一原则有助于让网站在各种情况下更易于被尽可能多的用户使用。希望这三种工具能帮助您做出出色的配色选择。