了解 CSS 中 :focus 和 :focus-visible 之间的区别
我已经了解了键盘可访问性的重要性,所以我知道聚焦元素的视觉指示非常重要。但众所周知的 :focus 伪类并不总是最适合这项工作。这就是 :focus-visible 的用武之地。让我们看看这两个伪类之间的差异,并探索有效使用它们的最佳实践。
什么是 :focus 伪类?
:focus 伪类是一个 CSS 选择器,它将样式应用于任何接收焦点的元素,无论焦点是如何触发的。这包括来自键盘导航、鼠标单击和触摸交互的焦点事件。
:focus 的用法示例
button:focus { outline: 2px solid blue; }
在此示例中,只要按钮获得焦点,无论用户是使用鼠标单击它、在触摸屏上点击它还是使用键盘导航到它,该按钮都会显示蓝色轮廓。
什么是 :focus-visible 伪类?
:focus-visible 伪类更加专业。仅当浏览器确定焦点应该可见时,它才将样式应用于元素。当用户通过键盘或辅助技术而不是通过鼠标或触摸输入进行导航时,通常会发生这种情况。
:focus-visible 的用法示例
button:focus-visible { outline: 2px solid blue; }
在这里,当通过键盘导航或其他通常需要可见焦点指示器的输入方法获得焦点时,按钮只会显示蓝色轮廓。
:focus 和 :focus-visible 之间的主要区别
:重点
- 行为: 适用于任何接收焦点的元素,无论输入法如何。
- 用例:确保与元素的所有交互都以视觉方式指示,无论是通过鼠标、键盘还是触摸。
:焦点-可见
- 行为: 仅当焦点可见时应用样式,例如使用键盘或辅助技术。
- 用例:非常适合您只想向键盘和辅助技术用户提供焦点指示器,同时避免为鼠标和触摸用户提供不必要的轮廓(通常是设计所需的)的场景。
无障碍影响
:重点
- 优点:
- 保证所有用户都可以看到某个元素何时获得焦点,这对于可访问性至关重要。
- 缺点:
- 可能会导致鼠标用户的体验不佳,因为在鼠标交互过程中可能会出现不必要的焦点样式。
:焦点-可见
- 优点:
- 仅在必要时显示焦点指示器,从而增强用户体验,从而为鼠标和触摸用户保持界面干净。
- 为键盘和辅助技术用户量身定制体验,为他们提供清晰的视觉提示。
- 缺点:
- 可能需要额外的考虑,以确保焦点指示器不会被意外省略,特别是在不支持 :focus-visible 的旧浏览器中。
- 在某些情况下,您可能希望向所有用户显示焦点指示器,无论输入法如何。
使用 :focus 和 :focus-visible 的最佳实践
为了实现最佳的可访问性和用户体验,在 CSS 中结合使用 :focus 和 :focus-visible 通常是一个好主意。
结合 :focus 和 :focus-visible
button:focus { outline: 2px solid blue; }
这是一个 Stackblitz 示例,展示了此类样式的外观,供您尝试和使用:
额外提示
- 使用键盘和辅助技术进行测试:确保您的 Web 应用程序可以使用键盘(Tab、Shift Tab 等)进行导航,并且焦点指示器对于依赖它们的人是可见的。在您的 e2e 测试套件中包含可访问性测试绝不是一个坏主意。
- 提供清晰的焦点指示器:确保焦点指示器突出且易于看到。微妙或难以发现的焦点指示器可能会严重影响依赖键盘导航的用户的可访问性。
结论
:focus-visible 伪类提供了一种更精细的方式来管理焦点指示器,提高可访问性和用户体验,特别是对于键盘和辅助技术用户。通过了解 :focus 和 :focus-visible 之间的差异,并在 CSS 中应用最佳实践,您可以创建更易于访问和用户友好的 Web 应用程序。
请记住,可访问性永远不应该是事后的想法。通过深思熟虑地应用焦点样式,您可以确保所有用户,无论他们如何与您的网站交互,都可以轻松导航和交互。
以上是理解 CSS 中 `:focus` 和 `:focus-visible` 之间的区别的详细内容。更多信息请关注PHP中文网其他相关文章!

在这篇文章中,布莱克·莫里(Blackle Mori)向您展示了一些骇客,同时试图推动同位HTML支持的极限。如果您敢于使用这些,以免您也被标记为CSS罪犯。

具有CSS的自定义光标很棒,但是我们可以将JavaScript提升到一个新的水平。使用JavaScript,我们可以在光标状态之间过渡,将动态文本放置在光标中,应用复杂的动画并应用过滤器。

互动CSS动画和元素相互启动的元素在2025年似乎更合理。虽然不需要在CSS中实施乒乓球,但CSS的灵活性和力量的增加,可以怀疑Lee&Aver Lee&Aver Lee有一天将是一场

有关利用CSS背景滤波器属性来样式用户界面的提示和技巧。您将学习如何在多个元素之间进行背景过滤器,并将它们与其他CSS图形效果集成在一起以创建精心设计的设计。

好吧,事实证明,SVG的内置动画功能从未按计划进行弃用。当然,CSS和JavaScript具有承载负载的能力,但是很高兴知道Smil并没有像以前那样死在水中

是的,让#039;跳上文字包装:Safari Technology Preview In Pretty Landing!但是请注意,它与在铬浏览器中的工作方式不同。

此CSS-tricks更新了,重点介绍了年鉴,最近的播客出现,新的CSS计数器指南以及增加了几位新作者,这些新作者贡献了有价值的内容。

在大多数情况下,人们展示了@Apply的@Apply功能,其中包括Tailwind的单个property实用程序之一(会改变单个CSS声明)。当以这种方式展示时,@Apply听起来似乎很有希望。如此明显


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器