如何仅从屏幕阅读器隐藏任何元素,而不是从普通用户的页面隐藏?

时间:2011-01-25 17:23:53

标签: css xhtml accessibility screen-readers

如何仅从屏幕阅读器隐藏任何元素,而不是普通用户的页面?

我知道这些片段,但我想隐藏屏幕重播中的内容,但不能从视觉上隐藏页面。 Sscreen阅读器应该跳过隐藏的部分。

/* Hide for both screenreaders and browsers
      css-discuss.incutio.com/wiki/Screenreader_Visibility */
    .hidden { display: none; visibility: hidden; }

/* Hide only visually, but have it available for screenreaders
    www.webaim.org/techniques/css/invisiblecontent/ ; &  j.mp/visuallyhidden ; */
   .visuallyhidden { position: absolute !important;   
    clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
    clip: rect(1px, 1px, 1px, 1px); }

/* Hide visually and from screenreaders, but maintain layout */
   .invisible { visibility: hidden; }

3 个答案:

答案 0 :(得分:6)

在元素上使用它:

aria-hidden="true"

这会将该元素显示为视力正常的用户,但不会被屏幕阅读器朗读。

答案 1 :(得分:3)

我认为迈克尔上面的回答将是完成你想要的最符合语义的正确方法。他指出,唯一的问题是在screenreader \ browser支持上。

快速而肮脏的方式是将您想要的任何内容显示为图像,然后为其指定一个空白的替代文本值,例如

<img src="visualcontentonly.png" alt="" />

您想要从屏幕阅读器用户隐藏的内容是什么?可能有更合适的方法来处理这个问题。虽然将其显示为图像会起作用,但从可访问性的角度来看可能会令人不悦,具体取决于内容是什么。

答案 2 :(得分:0)

我不确定屏幕阅读器是否会在新的CSS3语音模块中遵守任何内容,但它可能是您可以测试的内容,因为它似乎是最简单的选项,如果它有效。

http://www.w3.org/TR/css3-speech/