- From: Richard Schwerdtfeger <schwer@us.ibm.com>
- Date: Thu, 11 Jun 2015 17:24:11 -0500
- To: Dominic Mazzoni <dmazzoni@google.com>
- Cc: chaals@yandex-team.ru, John Foliot <john.foliot@deque.com>, HTML Accessibility Task Force <public-html-a11y@w3.org>, "public-pfwg@w3.org" <public-pfwg@w3.org>
- Message-ID: <OFA3101EA0.32F63E8D-ON86257E61.007A6F5D-86257E61.007B107F@us.ibm.com>
The ARIA task force agree to put it in the ARIA 1.1 editor's draft for review. I expect it to show up next week. There will be discussion on providing help information associated with it. The HTML working group can decide if it wants to use the ARIA property to provide greater user control over what keys can be rebound to it. The ARIA task force does not define browser functionality - that is up to the host languages and user agents or plugin providers. I co-authored the first access element draft which was first submitted in 2008. The accesskey discussion has gone on before that. The HTML working group needs to address the issue and I agree this does not interfere with that work but given how long it the accesskey issue was out there and nothing concrete has been done about it I don't think we should hold up the ARIA train for it. Thanks for doing all the great work to bring a proposal to the group Dominic! Rich Rich Schwerdtfeger From: Dominic Mazzoni <dmazzoni@google.com> To: chaals@yandex-team.ru, John Foliot <john.foliot@deque.com>, HTML Accessibility Task Force <public-html-a11y@w3.org> Cc: "public-pfwg@w3.org" <public-pfwg@w3.org> Date: 06/11/2015 10:37 AM Subject: Re: ACTION-1642: New aria-kbdshortcuts property (for Issue 711) Charles, I agree that an HTML5 feature allowing users to bind keyboard shortcuts to commands would be great, but I think that's out of the scope of this group, and I don't think that's an argument *against* also having aria-kbdshortcuts (or whatever we call it). If you have a concrete proposal for what this should look like, please post it to the relevant list and send us a link. I'd be happy to engage on that. One option would be to try to "fix" the accesskey spec. So yes, we should provide simpler, more straightforward ways for web authors to achieve what they want in a way that communicates all of the semantics to the browser and AT. However we also need to provide ways to let web authors implement things at a lower level and still describe those semantics to AT. - Dominic On Thu, Jun 11, 2015 at 4:12 AM <chaals@yandex-team.ru> wrote: Some thoughts on this: 10.06.2015, 18:09, "Dominic Mazzoni" <dmazzoni@google.com>: Answers to questions raised by both Joseph and Stefan: * The specified keyboard shortcut would activate a control, not focus it. If it's a button, it implies that pressing that shortcut clicks on the button. What if it is an input element - date picker, search boox, etc? In some cases, being able to focus is entirely reasonable. * Adding this attribute to an element does not change any browser behavior. Adding role=button to an element doesn't make it a button, it just informs AT that it acts like a button. Similarly, adding aria-kbdshortcuts to an element doesn't make those keyboard shortcuts function, it just informs AT that those keyboard shortcuts are available. It's up to the author to implement it. * Discoverability: AT such as screen readers could now announce the shortcut for a button or menu item upon focusing it, just like when a user explores a native menu item in a desktop app. It is still totally up to the author how to expose this keyboard shortcut to non-AT users. This is a problem, since authors are notoriously bad at getting this right. If there were browser-defined behaviour as there is for accesskey (although most browsers made dumb decisions about exactly what to define) the browser would be able to provide discoverability in a standard way to all users. That seems a vastly superior approach. * Remember, lots of web sites *already* have keyboard shortcuts that activate controls and menu items. This spec simply provides a consistent way to provide this information to AT. Otherwise, authors have to include this information in a control's label or description. Agreed. * Providing the keyboard shortcut in a standard format allows the AT to not only expose it to the user, it allows the AT to parse it, transform it, or act on it. For example, a screen reader could discover that a key conflicts with a built-in key and *automatically* suggest using the passthrough key. Or, other AT could let the user press one modifier key and then highlight all commands that can be activated using that modifier. These are not *primary* use cases, they are simply arguments in favor of making this a standardized, parseable attribute as opposed to just free text. Agreed. For what it is worth, any accesskey implementation that doesn't do this isn't particularly good. * How does this differ from accesskey? So many ways: - Accesskeys have different modifiers in every browser. See the Wikipedia page to get an idea of how confusing it is for web developers and users: http://en.wikipedia.org/wiki/Access_key - Accesskeys don't even have the same *behavior* in all browsers - some just focus, others activate. Both of those things are features. Different browsers work in different ways and serve different users. Insisting that all interfaces are the same is an anti-pattern. Consistency is indeed helpful, but there are different things to be consistent with - the same browser on a different device? A different browser on the same device? Native applications on windows desktops? - Accesskeys don't let you choose the modifier keys. Setting accesskey='h' means to press Alt+H in IE, there's no way to make a shortcut like Ctrl+H, Alt+Shift+H, or just 'H' with no modifier keys. This is a bug in HTML5, and in browser implementations. (As far as I know, Presto-based Opera was the only browser that got this right in a native implementation ;( ). - Web developers already have lots of other ways to support keyboard shortcuts in their web apps. Accesskeys are the only ones that are currently exposed to screen readers, but they're very limited, so web developers don't actually use them much. The fundamental problem is that they are limited by poor browser implementation. This proposal allows web developers to *implement* keyboard access however they choose, and simply *expose* the information about those shortcuts to AT in a consistent way. But makes it hard to expose the same features to most users, who don't connect via the accessibility API - including probably most users who rely on keyboard access. It is also a bad idea to have every developer try to write their own interface - it makes building consistency a nightmare. So if there is a way that *reduces* the desire of authors to specify the details of the UI they are adding, knowing that browsers will make it work, that would provide a big improvement in accessibility of the platform. * If a control has both accesskey and aria-kbdshortcuts, I think aria-kbdshortcuts should be the only one exposed to AT, just like aria-label overrides alt. * I agree about the concern about invisible controls, but I don't see a good alternative. If a control is invisible, it's not exposed to AT at all. If a web author wants a keyboard shortcut to be available even when its associated control is hidden, like a menu item, they should use CSS to hide the item in such a way that leaves it accessible to AT, such as by moving it offscreen or changing its z-index. It should be possible to assign accelerated access to e.g. a javascript function. While this may have a visual representation, in the mainstream use cases that are likely to power real uptake it quite possible doesn't. I worry that this proposal risks re-inventing accesskey, with some of the same mistakes and some special new ones. I think we could more readily fix accesskey to solve both sets of problems, but in any event I think it is a very bad idea to simply start down the path as if we had no knowledge or experience. -- Charles McCathie Nevile - web standards - CTO Office, Yandex chaals@yandex-team.ru - - - Find more at http://yandex.com
Attachments
- image/gif attachment: graycol.gif
Received on Thursday, 11 June 2015 22:24:47 UTC