- From: Matthew Raymond <mattraymond@earthlink.net>
- Date: Thu, 27 Sep 2007 21:50:31 -0400
- To: Richard Schwerdtfeger <schwer@us.ibm.com>
- CC: public-html <public-html@w3.org>, public-xhtml2@w3.org, Simon Pieters <simonp@opera.com>, "wai-xtech@w3.org" <wai-xtech@w3.org>, wai-xtech-request@w3.org
Richard Schwerdtfeger wrote: > I cannot support aria-role over role: > > I was one of the original creators for role. And I'm one of it's major opponents. > It's purpose is not limited to accessibility. No, but it's one of the two primary use cases, the other one being the roles specified for the XHTML namespace. > Choosing to limit to accessibility alone will create problems throughout > the W3C. Well, part of the idea was that |aria-role| would be a separate attribute from |role| that can be mapped to the |role| attribute or implemented independently, so I don't see why they can't coexist. That said, so long a |role| hasn't reached critical mass in the authoring community, I could care less how it disrupts the W3C. The W3C is here to create good specifications, and if they have to start over with some of them because a specific technology falls out of favor, so be it. Better to break unimplemented specs that to try to fix the ones already implemented. > One use case that is not accessibility related: role can take a value of > "main" which eludes to main content. A cell phone provider can take all > main content and move it to the first screen when rendering a web page. > This is not accessibility related. It is also being used, in general, > for content adaptation. The <article> element fulfills this use case. For that matter, a simple boolean attribute entitled "main" would do the same and allow attribute minimization: | <div main>[...]</div> How is it that boolean attributes and other markup are not sufficient to fulfill the |role| attribute's use case? Furthermore, you have yet to explain how to deal with interaction between multiple roles declared on the same element. How, for example, do you deal with declarations of "wairole:checkbox" and "wairole:radio" at the same time? The |aria-role| attribute resolves the problem by preventing it from happening in the first place. > We cannot hijack the role attribute for accessibility purposes alone due > to it's intended scope. As for the aria attributes using the aria- > preamble I have no problem as these have only been used for > accessibility. Ian's proposal for the attributes was excellent. You seem to be contradicting yourself. The |aria-role| attribute would have some duplicate functionality, but it would be separate from |role| and only take a limited range of values. That seems consistent with the way the "aria-" prefix is used for attributes like |waistate:checked| and such. In fact, using |aria-role| ensures that |role| doesn't need to be modified to treat WAI-ARIA roles as if they were in the same namespace as XHTML roles. > Google also is against adding unneeded characters which would increase > the download size. All the major search engine providers are counting > every character. Clarify: You have first-hand knowledge that Google is against my specific proposal? > Also, a number of groups are already implementing ARIA which use role: > Dojo, Yahoo, Google, SAS, SAP, lots of others. And yet the vast majority of web sites are HTML and cannot take advantage of the roles as-implemented because of the lack of support for namespaces. The |role| attribute you're proposing to add to HTML would be one limited to roles from only two namespaces with the namespace prefixes from one namespace removed. The XHTML roles conflict with many of the proposed new elements in HTML5. Thus, if you remove the XHTML roles to resolve the conflicts, you are left with only the ARIA roles, and |role| becomes a mere abbreviation of |aria-role|. Not that this would make sense even if you could do namespaces in HTML, because then you could just take advantage of attribute minimization and do this: | <div wairole:checkbox></div> That saves seven characters over using the |role| attribute: | <div role="wairole:checkbox"></div> In fact, even if you have an explicit boolean value, you haven't really saved characters: | <div wairole:checkbox="true"></div> The |role| attribute is an elegant solution to a problem that doesn't exist. There is nothing the it can express that couldn't be expressed with elements or simple attributes. It's greatest use case are the ones that have been specifically tailored to use |role| instead of other solutions that would be greater extensible, easier validation and parsing, and more structured markup.
Received on Friday, 28 September 2007 01:51:47 UTC