-
Notifications
You must be signed in to change notification settings - Fork 683
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[selectors] Add :role() pseudo-class #3596
Comments
I really like the idea of this and was thus going to take a stab at writing some proposed prose here, but .... from my recollection, and the minutes (both of which may be flawed), it feels like the 'key' things mentioned here really hinge on this being based off the computed role - like what is the actual role that this is playing. But, in discussing this with @alice, this might actually be pretty tricky because what the computed role is sometimes involves fairly complex checking and tree walking. |
I'd be interested to know what use cases @cookiecrook had in mind here. I agree with @bkardell, it seems to be implied that this refers to computed ARIA-equivalent role (i.e. a Assuming that to be the case, implementing this could be quite complex. |
That is the case, but Alice is correct that implementation proved significantly more challenging than expected. Style parsing needs to happen before layout and rendering. In WebKit (and Blink, maybe more) the accessibility tree is computed based on the render tree. Since accessibility can change the roles (or refuse to change the roles of malformed nodes), current implementations could result in one of the following:
We left off that path by determining that a non-trivial amount of WebCore Accessibility would need to be extracted from the accessibility-specific codebase and refactored for use prior to layout. It’s not impossible, but it’s quite a bit more than anyone was willing to commit to. A WICG incubator may be a good path forward for this one. You’ll need implementor involvement and buy-in before the |
@bkardell wrote:
As one example of this complexity, review In addition to hierarchical validation and well-formedness ( |
I have a strong feeling that distinguishing data tables from layout table is a special, largely historical, exceptional case, that should be not generalized as a rule. Tables were used for layout when there were effectively no alternative. Tables are probably the only HTML elements misused this way because of their default styling. There never were such thing as "Layout lists" or something. The "HTML is meaning, CSS is presentation" mantra is one of the first things that modern web developers learn. Many web developers try hard to make their markup meaningful for non-visual output (e.g. wrapping navigation links into list items) while presenting it visually as design requires (e.g. as a horizontal flexbox "ribbon"). When browsers deduce from this that the author "didn't mean" a list there, it feels like a huge disappointment with the very idea of the semantic markup (at least, I felt so). I admit that there definitely might be other special cases where styling distorts the initial meaning of elements for sighted users and ATs have to convey this distortion, but they should probably be investigated and specified individually. The general rule should be that CSS doesn't affect the implied meaning of the content unless there is an absolute and consensus-approved necessity to do so. Similarly to what we have already decided in #2355. |
So, |
@Crissov can you explain that comment a little more? |
@SelenIT - I think @alice or @cookiecrook can speak better to how unique that particular example is, but there's definitely additional relationships and complexity which I'm unsure even happens at the right stage right now to be considered in a selector. I believe some roles may actually rely on CSS application in order to determine their computed role, which would be problematic. I'm not suggesting that this isn't a thing that shouldn't be supported, and if we were designing all of the things fresh, this is a thing I would really want to keep in mind - I just wonder if we might not need to think about this a lot more and maybe work on some efforts to detangle - or maybe thinks about revise the ask somehow in a way that could be achievable but not just add confusion for developers about one more hard to understand kind of value? |
@bkardell At first, I wondered how |
Also, adding completely new special syntax might not work so well with #3264. |
@SelenIT wrote:
Here's the same concept for layout lists (a.k.a. "list-itis") versus semantic lists: "div-itis" is also a thing, though thankfully |
Not to diverge too far off topic, but some additional threads on that are here: |
@cookiecrook, thank you for these links. I completely agree with the Priority of Constituencies principle you cite. Hovewer, my point that there is no such thing as layout lists still stands. The term "layout lists" is a misnomer. There is a huge difference between (mis)using specific elements because of their styling and (mis)using them despite their styling, making extra effort to "overcome" it. I'd rather call them something like "unobvious lists" or "cryptic lists":) Indeed, sometimes the "listitis" makes a page too verbose for screenreader users, and they definitely may feel some of the extra list-related info redundant and removing it can look helpful for them. I agree with this intent, but one premise of the issue 134187 seems wrong to me:
How big are chances that someone uses a specific element not caring about its meaning and makes extra effort removing its styles, while there is much easier-to-use alternative ( I'm pretty sure that the primary reason for overusing lists (instead of divs and other much easier to style elements) is intent to convey extra semantics (e.g. "this is a list of 5 horizontal navigation links" or "this is a 15 items portion of the catalog list ordered by price") that sighted users can usually deduce from the visual context (how the items are grouped together, which common decorations distinguish them from other elements on the page, etc.). And I'm not sure that hiding this intended meaning that authors did put into the markup from the non-visual users really serves the users' priority. Indeed, some heuristics to treat different type of lists differently could be useful, but styling is probably not the best criterion for this. |
https://bugs.webkit.org/show_bug.cgi?id=243151 Reviewed by Ryosuke Niwa. The matching is not implemented, and it's not part of the spec: w3c/csswg-drafts#3596. Let's remove since it's confusing. * Source/WebCore/css/CSSSelector.cpp: (WebCore::appendPseudoClassFunctionTail): (WebCore::CSSSelector::selectorText const): * Source/WebCore/css/CSSSelector.h: * Source/WebCore/css/SelectorChecker.cpp: (WebCore::SelectorChecker::checkOne const): * Source/WebCore/css/SelectorPseudoClassAndCompatibilityElementMap.in: * Source/WebCore/css/parser/CSSSelectorParser.cpp: (WebCore::isOnlyPseudoClassFunction): (WebCore::CSSSelectorParser::consumePseudo): * Source/WebCore/cssjit/SelectorCompiler.cpp: (WebCore::SelectorCompiler::addPseudoClassType): * LayoutTests/fast/css/css-selector-text-expected.txt: * LayoutTests/fast/css/css-selector-text.html: * LayoutTests/fast/css/css-set-selector-text-expected.txt: * LayoutTests/fast/css/css-set-selector-text.html: * LayoutTests/fast/selectors/invalid-functional-pseudo-class-expected.txt: * LayoutTests/fast/selectors/invalid-functional-pseudo-class.html: Canonical link: https://commits.webkit.org/252786@main
https://bugs.webkit.org/show_bug.cgi?id=243151 Reviewed by Ryosuke Niwa. The matching is not implemented, and it's not part of the spec: w3c/csswg-drafts#3596. Let's remove since it's confusing. * Source/WebCore/css/CSSSelector.cpp: (WebCore::appendPseudoClassFunctionTail): (WebCore::CSSSelector::selectorText const): * Source/WebCore/css/CSSSelector.h: * Source/WebCore/css/SelectorChecker.cpp: (WebCore::SelectorChecker::checkOne const): * Source/WebCore/css/SelectorPseudoClassAndCompatibilityElementMap.in: * Source/WebCore/css/parser/CSSSelectorParser.cpp: (WebCore::isOnlyPseudoClassFunction): (WebCore::CSSSelectorParser::consumePseudo): * Source/WebCore/cssjit/SelectorCompiler.cpp: (WebCore::SelectorCompiler::addPseudoClassType): * LayoutTests/fast/css/css-selector-text-expected.txt: * LayoutTests/fast/css/css-selector-text.html: * LayoutTests/fast/css/css-set-selector-text-expected.txt: * LayoutTests/fast/css/css-set-selector-text.html: * LayoutTests/fast/selectors/invalid-functional-pseudo-class-expected.txt: * LayoutTests/fast/selectors/invalid-functional-pseudo-class.html: Canonical link: https://commits.webkit.org/252786@main
The CSS Working Group just discussed The full IRC log of that discussion<fantasai> Subtopic: :role() pseudo-class<jcraig> scribe- <jcraig> s/scribe-// <fantasai> Rossen_: Can someone summarize this issue? <fantasai> github: https://github.com//issues/3596 <fantasai> matatk: Is this a shortcut for the attribute selector? Seems to be syntactic sugar <fantasai> fremy: There are some differences, handles roles that are implied as well <TabAtkins> Yeah, handling implicit roles is the big point <fantasai> PaulG: Map to computed role from Chrome's implementation <fantasai> fremy: could do it yourself with correct attribute, but simplified way <fantasai> heycam: is computed role only a function of role and tag name, or more things? <fantasai> matatk: Landmarks, I maintain an extension to navigate, and where they are in teh document determines what they are <fantasai> ... e.g. if header/footer are scoped to page you have page header/footer <fantasai> ... but inside an article, not the same landmarks <fantasai> ... not that simple, so I can understand why if browser does the matching it would be useful <fantasai> PaulG: What's the status of it? <fantasai> Rossen_: There's a group discussing this with ARIA <fantasai> TabAtkins: Several years back we resolved to add this, to expose computed roles to selectors <fantasai> ... several years after that, I raised this issue saying that I was supposed to draft it <fantasai> ... still haven't written it <fantasai> ... if any concerns about it, please file issues/comments <fantasai> ... otherwise this is just something that needs to be written by me at some point, because I signed up for it <fantasai> Rossen_: With this, we are out of time <fantasai> Rossen_: thanks APA for joining us <fantasai> Janina: Thanks for your hospitality <fantasai> Rossen_: please do engage on the issues <fantasai> ... we love to work with ou <fantasai> ... if you find a liaison, would love to work with them <fantasai> s/ou/you/ <fantasai> matatk: File issues is the theme for this week! <fantasai> <br duration=10m> |
I discovered this issue after thinking about how to write some generic code for a web component that will use an event handler to find the nearest ancestor with a specific role and then get some more information about it. It looks like there's a current limitation, where a custom element has role set via myCustomTable.addEventHandler('click', ({ target }) => {
// This won't find an element whose role is set with ElementInternals.role
const clickedCell = target.closest('td, [role="cell"]');
if (clickedCell) {
// There's a separate, but similar problem here that AOM should address
const [x, y] = getColumnAndRowIndex(clickedCell);
handleCellClick(x, y);
}
}); Not only would |
Here's a more complete thread of the background on layout lists and why I would expect WebKit's behavior to remain. Regardless, the lists example tangential to the point of this issue. There are other contextual role roles in ARIA and HTML-AAM. While I agree that it'd be possible to extract some or all of this logic from the accessibility runtime and insert it into the mainstream runtime, it's a non-trivial amount of work that, so far, no implementor I'm aware of has agreed to take on. |
To echo my comment from #10222, I’m not sure what the use cases are here. Is the idea that authors would switch their default styles from using the kinds of long selectors discussed in #2296 and would use |
The apparent need for additional roles in ARIA does not negate the usefulness of a role selector in CSS. If that’s an issue in practice it should be brought up in the proper place. (The following is a draft comment from a while ago which I rediscovered just now and shall publish without any reevaluation:) I’d like to point out that someone could create an external specification that assigned ARIA implicit default roles to elements in very different markup languages, e.g. ones without obvious element names like Markdown, thereby paving the path of adding direct CSS styling support to them. |
In https://lists.w3.org/Archives/Public/www-style/2015Jan/0004.html (Oct 2014 Santa Clara f2f), we resolved to add a
:role()
pseudo-class, to match based on ARIA roles easily:minutes excerpt
I volunteered to write the text, but clearly never did. ^_^
The text was updated successfully, but these errors were encountered: