What is the appropriate way to hide icons from screen readers(向屏幕阅读器隐藏图标的适当方式是什么)
问题描述
在我的Web应用程序中,我为自己设置了一个完全由图标组成的字体。我使用这些图标来补充应用程序中的标题和副标题,使其在视觉上更具吸引力。
但是,像JAWS这样的屏幕阅读器会读出这些内容,这会给屏幕阅读器的用户带来不愉快的体验。
例如,字符c
显示云的图像。我以这种方式使用它来补充标题,例如<h1>
:
<span class="my-font">c</span>
现在我希望屏幕阅读器完全忽略这一点,因为这只是对现有标题的补充,不会为页面上的内容添加任何新的含义。通过我的研究,我发现了两种可能性:
aria-hidden="true"
或role="presentation"
我只是不确定这两个中的哪一个(或者两个)适合我正在努力实现的目标。
推荐答案
您应该使用aria-hidden="true"
属性,该属性表示:
表示该元素及其所有子元素对于作者实现的任何用户都不可见或不可见。
这意味着该元素不应该被任何用户感知。因此使用:
<span class="my-font" aria-hidden="true">c</span>
如果图标应该是一个链接,或者不仅仅是为了装饰,我建议你在图标旁边加上一些文字,这样屏幕读者就知道它是什么了。您可以将文本移出屏幕,以便只有屏幕阅读器才能看到它。
HTML
<span>
<span class="my-font" aria-hidden="true">c</span>
<span class="screen-reader">About me</span>
</span>
css
.screen-reader {
position:absolute;
top:-9999px;
left:-9999px;
}
这篇关于向屏幕阅读器隐藏图标的适当方式是什么的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:向屏幕阅读器隐藏图标的适当方式是什么


基础教程推荐
- 如何添加到目前为止的天数? 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- 检查 HTML5 拖放文件类型 2022-01-01
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01