如何在角度变化状态下让屏幕阅读器读取整个页面?

lui*_*uix 6 javascript firefox accessibility angularjs nvda

要求:在每个页面上更改屏幕阅读器必须阅读整个页面内容.

我们使用firefox + NVDA进行测试,因为角度没有"更改页面",我们尝试以下内容使其在更改状态时读取整个页面:

aria-live="assertive"
Run Code Online (Sandbox Code Playgroud)

这在很大程度上是读取我们网站中文本的变化,但它只读取它的添加内容,在我们的例子中我们有一个表被填充,ng-repeat它读取了添加的信息,但没有任何上下文(它没有说明是哪一行或列正在阅读)

另一个问题是形式,当被角度填充时,屏幕阅读器将在它们被角度填充之前读取它,这已经解决了$timeout但仍然在aria-live读取更改时它会跳过某些部分,如果我们添加aria-atomic到强制读取,我们有一些选择有多个选项,那些被阅读(所有这些,我们有超过一百个选项).这不是屏幕阅读器读取的方式,它们只读取前十个选项或单击它们时可见的选项.

请记住,如果没有任何aria-live或aria-atomic,当您以角度更改状态时,不会通知用户任何更改.

几乎放弃后我们决定可能我们的重点是错误的,我们需要让每个州都有自己的页面,所以我们使用了以下内容:

function ForceNVDARead() {
    $(window).on('hashchange', function () {
        location.reload();
    });
}
Run Code Online (Sandbox Code Playgroud)

对于URL中的每个更改,这将强制重新加载.这很有效,一切都被正确阅读,我们几乎认为这解决了一切.除此之外导致从客户端到我们的服务器的双重请求.

有没有办法让NVDA读取像常规页面加载一样的角状态的内容,而不必强制重新加载页面?

请不要仅仅使用咏叹调角色或类似的东西,这对我们已经有了它们,我们需要应用程序在更改状态时读取所有内容.

感谢任何帮助,我们即将放弃,并在没有角度的情况下重新启动项目,因为我们无法实现可访问性要求.

Ala*_*irC 8

要求:在每个页面上更改屏幕阅读器必须阅读整个页面内容.

从可访问性的角度来看,这基本上不是一个要求,它相当于让某人在屏幕上一次读取所有内容,或者使用 readquick,这不是自然的用法.

使用Angular时,屏幕阅读器可访问性是可行的,但我们需要重置一些假设:

  • 当您有页面更新时,关键是管理焦点,并移动到新内容.这允许人们以自己的方式阅读,而不是你假设他们必须阅读的方式.
  • ARIA live用于页面上其他地方的小更新(远离键盘焦点),而不是整个内容,这不是答案,我会完全放弃它.
  • 如果人们在加载之前阅读表格,那可能是试图用ARIA-live强制阅读的副作用.如果没有,那么尝试使用焦点管理将焦点放在表单的顶部.
  • 可能值得阅读有关NVDA使用的教程,或与"本地"用户交谈.我可以从经验中说,你没有像最终用户那样使用它,所以要更好地理解"正常"的交互是什么样的.

如果你放弃使用ARIA-live并进行焦点管理,你可能会解决大多数问题,但是从不同的角度来看可能会有更多的问题.