I am attempting to make my ember.js app more accessible and am doing my testing via Apple's built-in VoiceOver utility. I'm adding ariaRoles as necessary to my views and tacking on aria-label attributes where the purpose of navigation is unclear. I'm having issues getting the focus on modal alerts, as the reader's focus stays on the page items behind the modal. Does anyone have experience handling focus on modal alerts for screen readers? I'm under the impression that declaring "ariaRole:'alertDialog'" in my view sets the appropriate role for such a dialog, and it is possible that the focus behavior for this role differs between screen readers. Thanks!!!
可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
回答1:
I don't have first hand experience with modal stuff. Essentially your issue is you are throwing on an ARIA role, and kind of expect it to work. You need to do more than that. You need to keep the following in mind:
- Once the link/button is pressed, move focus to the modal window/dialog/popup. Most modal elements are simply a
<div>
. You can give the<div>
an attribute oftabindex="-1"
. - Trap focus inside the modal window.
- Allow the user to press escape to close
- When closed, move focus back to link/button
Resources
- keyboard accessibility with lightboxes
- Similar question at UX StackExchange
- Demo modal dialog - I think this is still under dev (I haven't heard from the author for a while).
- jQuery Google Group thread (Hans is the top guy or one of, for this stuff)