- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个<dialog>
该元素在打开时会使用 AJAX 从服务器请求一些内容。当内容返回时(当然可以是任意时间长度,具体取决于连接速度和内容量),新内容将动态附加到对话框中。
如何让屏幕阅读器用户意识到此内容现已存在并且他们可以移至该内容?插入内容后是否应将焦点移至内容?
<小时/>我正在使用a11y-dialog library打开对话框。
我有 dialog
的容器设置为 aria-live="polite"
并添加aria-busy="true"
一旦我启动 AJAX 请求。
aria-busy
然后设置为 false
一旦 AJAX 请求返回并且内容被添加到容器中。
这可以在内容到达时立即宣布内容,但是,它会读取输入的所有文本,在某些情况下可能是几个段落。我对屏幕阅读器控件的经验有限,因此我不确定是否有办法中断此自动阅读过程。
这是 dialog
的 HTML 代码。 AJAX 容器的 ID 为 #dialog-ajax-wrapper
.
<div class="dialog js-dialog" id="dialog" hidden>
<div class="dialog__overlay" tabindex="-1" data-a11y-dialog-hide></div>
<dialog class="dialog__native" aria-labelledby="dialog-title">
<div class="dialog__inner">
<button class="dialog__close" type="button" data-a11y-dialog-hide aria-label="Close dialog window">
X
</button>
<div class="dialog__ajax" id="dialog-ajax-wrapper" aria-live="polite"></div>
<div class="dialog__loader" aria-hidden="true"><div class="loader"></div></div>
</div> <!-- /.dialog__inner -->
</dialog>
</div>
我希望以某种方式宣布正在加载内容的事实,但目前还没有。然后,一旦插入内容,就会宣布但不会完整阅读。
由于焦点转移到关闭按钮,情况变得更加复杂。由于在加载内容之前没有其他可聚焦的元素,因此按 Tab 键或尝试导航不会产生任何结果,这可能会导致用户认为没有任何可用的内容并离开页面。
这是正确的方法还是有更好的方法?
最佳答案
How can I make screen reader users aware that this content now exists and that they can move to it? Should focus be moved to the content once it is inserted?
聚焦静态文本或使其可聚焦并不是一个好主意。用户可能认为他可以与文本进行交互,但事实并非如此。基本的 react 是“它不起作用”。
一般来说,在对话框中放置焦点的规则如下:
因此,在您的情况下,您是正确的,焦点必须保持在“确定”或“关闭”按钮上,并且不应移开。
This works to announce the content as soon as it arrives, however, it reads all text entered, which in some cases can be several paragraphs. My experience with the screen reader controls is limited, so I'm unsure if there is a way to interrupt this automatic reading process.
不用担心文本长度。当然,有办法在读完之前停止阅读、重复阅读、一次读一段、一句话或一个词。
我鼓励您阅读有关多个屏幕阅读器的文档或教程。最受欢迎的是windows下的Jaws和NVDA,Mac和iOS下的VoiceOver,Android下的Talkback...
I would expect the fact that content is loading to be announced in someway, which it currently isn't.
如果加载速度足够快,则根本没有理由宣布加载。我希望这是你的情况。从根本上来说,一旦出现对话框,我就不想等待很长时间才能看到内容。
如果加载需要一段时间,如果仅在加载所有内容时才出现该对话框可能会更好。这将消除您对加载对话框内容时可能发生的情况以及用户可能会想什么的担忧。
您可以显示单独的加载指示器而不是空对话框。如果您这样做,请不要忘记使用 aria-live 以便宣布加载。
Then once the content is inserted, it is announced but not read in its entirety.
当内容变得太长时,普通屏幕阅读器用户无论如何都会开始使用导航快捷方式,例如箭头键或左/右扫动,而不是等待一次读取所有内容。所以不用担心,如果您的文本通过这种导航保持可访问就足够了。
关于javascript - 对话框应如何向屏幕阅读器用户宣布动态内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57526609/
我最近为我的一个 iPhone 应用程序上传了更新,现在该应用程序刚刚准备好销售,但我只更新 iPhone 6 的屏幕截图,而不更新其他屏幕截图。现在我明白了,它们是新游戏的旧屏幕,这可能会让用户感到
我需要清除 Scala 中的控制台屏幕 我尝试过标准 ANSI Clear 屏幕,rosettacode.org 建议将其称为“终端控制/清除屏幕”here object Cls extends Ap
我需要清除 Scala 中的控制台屏幕 我尝试过标准 ANSI Clear 屏幕,rosettacode.org 建议将其称为“终端控制/清除屏幕”here object Cls extends Ap
我将从头开始,我正在开发一个跨越多个监视器的应用程序,每个监视器将包含一个 WPF 窗口,并且这些窗口使用一个 View 模型类进行控制。现在假设我在 200,300 (x,y) 处的所有窗口上都有一
谁能告诉我如何阻止矩形在我的游戏中离开面板(屏幕)?矩形随着击键并排移动。 最佳答案 这是你应该做的: 1. 跟踪矩形的 (x,y) 坐标。 2. 确保矩形的x + width 不大于JPanel 的
我正在尝试检测电源按钮是否在 4 秒内被按下 3 次。以下代码无效。 public class PowerButtonReceiver extends BroadcastReceiver{ s
我为我的新网上商店制作了一个横幅,但有一个问题。例如,当网站在我的笔记本电脑上显示为全尺寸时,横幅非常适合,但是当我在移动设备、笔记本电脑和较小尺寸的网站上看到该网站时,横幅就不合适了。我真的希望你们
我希望这个问题能够得到解决: 给定,屏幕 session 正在运行,并在终端中打开(附加)。 问题。 如果终端 session 终止,但未与屏幕 session 分离,则屏幕 session 中运行的
如何在点击通知时转到特定屏幕?我在 javascript 中使用了云功能,当我点击通知时,它打开了我的应用程序而不是特定的屏幕 _fcm.configure( onMessage: (Map m
Qt 确实支持像素比率 (devicePixelRatio),这在我的各种桌面上是不同的: ) 桌面 w1920 h1080 - 比例:1 ) 桌面 w3840 h2160 与 qputenv("QT
我一直在做一些研究,发现了这种情况。如果要写入STDOUT(屏幕),将无法执行多线程脚本,该脚本通过简单的单线程脚本可以更快地打印数据。但是,如果您写入这样的文件: myPrinter.perl >
我是 ABAP 的新手,我想制作一个具有多个屏幕和一个初始主屏幕的程序,可以在其中看到所有程序屏幕的列表。我知道我可以对它们进行硬编码,但应该有更好的方法。 如果有任何类型的字段/区域,我需要使此列表
我目前正在探索创建越狱调整。我想解锁手机屏幕。这是怎么做到的?在 iOS 7 上可以使用哪些私有(private) API 来实现这一点? 最佳答案 如果我们谈论越狱,那么您可以编写一个 Spring
我正在寻找一种方法来关闭 iPhone 屏幕而不让 iPhone 进入休眠状态。我真的不介意关闭屏幕是否违反苹果规则。将窗口 alpha 设置为 0 可以解决问题吗?我可以更改某种 boolean 值
我在 iTerm2 中使用 tmux。 当我在 bash 中时,使用 Ctrl-L 清除屏幕有效,但在我拖尾服务器日志时不起作用。我该如何解决? 最佳答案 您可以使用 send-keys -R 清除当
如何以编程方式锁定和解锁 iPhone 的主屏幕(即设备本身)? 最佳答案 这是不可能的。但是,您可以在应用程序运行时“阻止”手机锁定。 [UIApplication sharedApplicatio
我的任务是创建社交网络 我有一个主页,显示用户通过 Canvas 创建的所有绘图。用户可以在自己的绘图上绘图,并且可以添加也有权在其绘图上绘图的贡献者。问题是他们可以以某种方式同时绘制。 我想做的是,
退出后,如何从我在应用程序中打开的最后一个屏幕继续。 比如说我有屏幕A,B和C,并且在关闭应用程序之前我在屏幕B上。我的问题是当我再次打开应用程序时如何进入屏幕B。 最佳答案 当SharedPrefe
我试图停止一个进程,然后休眠10秒钟,杀死下一个进程再休眠10秒钟,然后启动另一个进程。问题是一切都立即运行。所以我想开始的过程没有运行,因为其他人都没有停止。 Start-Process Power
我正在尝试以 HW 身份进行测验。我输入的回复应该会出现在屏幕上,但事实并非如此。我使用函数response()多次检查了“15”行和“17”行中出了什么问题。我没有发现任何错误,需要调试和编写正确语
我是一名优秀的程序员,十分优秀!