- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我只是注意到,虽然 aria-label
, aria-labelledby
和 aria-describedby
据说属性适用于每个元素(参见 https://www.w3.org/WAI/PF/aria-1.1/states_and_properties#aria-describedby ),但它们似乎只适用于少数元素,如 a
,而不是例如div
或 p
在 NVDA 和 JAWS 中。
我创建了一个小代码笔来演示这个问题(使用浏览和焦点模式浏览它):
https://codepen.io/jmuheim/pen/avWbPe
例如,在 NVDA 中,在 a
上元素,aria-label
和 aria-labelledby
似乎在浏览和聚焦模式下都可以工作。但是aria-describedby
仅在焦点模式下公布,不在浏览模式下公布。
对于 input
元素,似乎没有一个属性在浏览模式下工作,但都在焦点模式下工作。
对于“裸”文本元素,如 p
或 div
,这些属性似乎都不起作用。
在 JAWS 中,它的行为非常相似,但至少对于 p
元素,当存在 aria-describedby
时,它宣布可以通过按“JAWS + alt + r”来阅读描述。
我真的没有看到明确的模式,所以我想知道屏幕阅读器中如何使用这些属性的一般规则是什么?或者更好:为什么它们不像规范建议的那样简单地适用于每个元素?
最佳答案
ARIA 没有定义辅助技术如何暴露 UI。它确实定义了 browsers are required通过可访问性 API 公开角色、状态和属性。通常与 HTML 相同,HTML 规范没有定义/要求 UI,这由浏览器决定。
对于 aria-label(例如),ARIA 要求将 aria-label 映射到 accessibility APIs 中的可访问名称属性。 ,这不是要求屏幕阅读器在任何给定元素上宣布或不宣布它(即作为听觉 UI 的一部分公开)。
一般观察规则是屏幕阅读器将宣布 accessible names and accessible descriptions在 interactive elements .他们将在大多数 grouping elements 上宣布可访问的名称和 sectioning elements .他们将宣布都不是 在大多数 text level elements .
注:以上也适用于任何默认语义被 ARIA 角色覆盖的元素。例如 ARIA widget roles将同时公布 acc 名称和描述,就像原生 HTML 交互元素一样。
关于accessibility - aria-label、aria-labelledby 和 aria-describedby : very unforeseeable behaviour in screenreaders,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32951169/
我是 ARIA 角色的新手。如果我有工具提示类型功能,即如果有人单击问号按钮,会显示更多文本详细说明如何填写表单字段,我应该使用 aria-expanded 属性、aria-hidden 属性还是两者
我正在查看一些代码,其中一个标签具有属性 aria-owns 和 aria-expanded。我用谷歌搜索了它们,但没有找到足够的细节来完全理解它们的作用。 有人可以解释一下这些特定属性的用途吗?我对
当我通过 W3C 验证器运行它时,几天前使用无错误通过的 HTML 5 代码现在显示错误。错误看起来像这样: 元素 li 缺少以下一个或多个属性:aria-checked、aria-expanded、
有人可以详细说明aria-live="assertive"之间的区别吗?和 aria-live="polite" ? 据我了解 aria-live="assertive"将获得更高的优先级并清除队列,
我只是注意到,虽然 aria-label , aria-labelledby和 aria-describedby据说属性适用于每个元素(参见 https://www.w3.org/WAI/PF/ari
在我的网站上,用户可以单击“实时聊天”按钮,然后会出现一个聊天窗口。我正在寻找一些文本来读出(对于使用屏幕阅读器的辅助用户) 当聊天窗口出现时,焦点将转到输入文本框 - 用户可以在其中输入文本与顾问聊
W3C 将 WAI-ARIA 角色分为四组: 抽象角色 小部件角色 文档结构角色 标志性角色 有人可以解释一下抽象角色类别吗? 最佳答案 规范中确实提到: Abstract roles are the
W3C 将 WAI-ARIA 角色分为四组: 抽象角色 微件角色 文档结构角色 里程碑式的角色 有人可以解释抽象角色类别吗? 最佳答案 它确实在规范中说: Abstract roles are the
我试图让 voiceover 只读取 aria-describedby,但它是这样读取的(“我是一个按钮”未被读取) : 而如果有一个定义了 id aria-describedby="modal-la
人们问过 aria-controls 和 aria-owns 之间的区别。 aria-controls 是基于层次结构的父子关系,而 aria-owns 不是。 我想变得非常具体。 aria-cont
我已经四处搜索,如果可以将 aria-label 组合起来,我没有找到任何信息。和 aria-describedby对于一个元素,它是否会导致使用屏幕阅读器的人感到困惑? 我有一个包含许多项目的列表,
我有一个页面,我应该可以在没有太多更改的情况下访问该页面。 页面中的一个组合框被编码,以便在单击输入框时,div 的内容被复制到同一页面中的 iframe 元素中,并且该 iframe 在输入框下方可
使用时对元素的真正影响是什么 aria-owns="id" 和(!) aria-controls="id" 当使用这两个属性时,浏览器如何通知屏幕阅读器? 最佳答案 两个aria-controls和
使用 Bootstrap 模式,我经常看到这些 aria 属性,但我从来不知道如何使用它们。 有谁知道什么情况下使用这些属性?我用谷歌搜索——只是没有找到任何直接的答案。 最佳答案 HTML5 ARI
我想确定当用户单击其后代时可以自动隐藏一个元素(使用 JavaScript 来实现)。 例如: A Link 这是正确的方法吗? 最佳答案 虽然您可以创建自定义
使用 jQuery 在 #div1 中添加角色警报,读取 #div2 内容,即使它对于 JAWS 来说是隐藏的。 some content some con
我正在尝试将 aria-label 添加到网站上没有的所有链接。我想使用链接文本作为 aria-label。 $(document).ready(function () { $("a").each
我在互联网和 Angular Aria 文档上进行了搜索——它没有提到 aria-expanded 或 aria-selected? 有没有办法实现这个? 这将使: 谢谢。 最佳答案 我使用 ng
我发现了两种使用 aria- 属性标记区域的方法。 第一个: Blah-blah 第二个: Search results Blah-blah JAWS 读取它们完全相同。那
我有一个工具栏与各种按钮的列表。在某些情况下,按钮有一个标签,在其他情况下,它使用图像。。两者都被生成为具有到包含div的aria-Labelledby,该div具有标题属性。屏幕阅读器(NVDA,叙
我是一名优秀的程序员,十分优秀!