-
Notifications
You must be signed in to change notification settings - Fork 266
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
Deprecating SC 4.1.1 #770
Comments
Let’s be sure to drag @stevefaulkner into this discussion! |
We often see links inside of buttons and other nesting issues that aren't clearly covered by SC but don't work well with assistive technology. This is the type of issue that 4.1.1 may still be needed for. |
Excellent start of this discussion @WilcoFiers . There are two minor corrections about the intent of the Success Criteria parts, from my memory of when we wrote it. Requirement 1: Elements have complete start and end tags. This was a very simple requirement that anything that opened needed to be closed (if closing it is in the spec). Your example of Requirement 2: |
The other part of this discussion was that issues with duplicate ids that impacted the user such as references to labels and aria-labelledby, etc. would be caught under other SC like 1.3.1 and 4.1.2. So I think people agree that duplicate ids can be an issue -- but they generally result in violations to other SC -- @WilcoFiers this is an important concept to capture in the doc. |
@mraccess77 wrote:
Jon, could you post a cleanish example of this? (On a live page somewhere.) It seems to me like the simplest way to resolve this issue would be a single example demonstrating that we still need 4.1.1 (at least for now). |
I know of lots of wrongly nested roles when using ARIA which this SC should cover, but doesn't, as it only speaks of "elements". Same Jon talks about... 4.1.2. Passes but still confuses UA/AT like role button nested in role textbox. Enough to add/extend in Understanding doc OR new SC? |
I feel pretty strongly that this should be new SC. I think it is okay that an SC written in 2008 misses catching common mistakes developers make with ARIA. I am not really okay with changing Understanding to have new normative requirements. Likewise, I feel like the note attached to 4.1.2 should really guide our saying if some particularly poor code fails 4.1.2 or not. |
+1 to Bruce - a new SC rather than modifying the intent & scope of the
original 4.1.1
JF
…On Thu, Jun 6, 2019 at 12:35 PM bruce-usab ***@***.***> wrote:
Enough to add/extend in Understanding doc OR new SC?
I feel pretty strongly that should be a new SC. I think is okay that an SC
written in 2008 misses ARIA. I am not really okay with saying that 4.1.1
catches wrongly nested ARIA roles. Likewise, I feel like the note attached
to 4.1.2 should really guide our saying if some particularly poor code
fails or not.
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub
<#770?email_source=notifications&email_token=AAJL445COETPIHFAFTEDLSTPZFDGLA5CNFSM4HVAQSU2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXDTF3Y#issuecomment-499593967>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAJL44YIQLHUGEK7UWTAYZLPZFDGLANCNFSM4HVAQSUQ>
.
--
*John Foliot* | Principal Accessibility Strategist | W3C AC Representative
Deque Systems - Accessibility for Good
deque.com
|
+1 to new SC
…On Thu, Jun 6, 2019, 1:46 PM John Foliot ***@***.***> wrote:
+1 to Bruce - a new SC rather than modifying the intent & scope of the
original 4.1.1
JF
On Thu, Jun 6, 2019 at 12:35 PM bruce-usab ***@***.***>
wrote:
> Enough to add/extend in Understanding doc OR new SC?
>
> I feel pretty strongly that should be a new SC. I think is okay that an
SC
> written in 2008 misses ARIA. I am not really okay with saying that 4.1.1
> catches wrongly nested ARIA roles. Likewise, I feel like the note
attached
> to 4.1.2 should really guide our saying if some particularly poor code
> fails or not.
>
> —
> You are receiving this because you are subscribed to this thread.
> Reply to this email directly, view it on GitHub
> <
#770?email_source=notifications&email_token=AAJL445COETPIHFAFTEDLSTPZFDGLA5CNFSM4HVAQSU2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXDTF3Y#issuecomment-499593967
>,
> or mute the thread
> <
https://github.com/notifications/unsubscribe-auth/AAJL44YIQLHUGEK7UWTAYZLPZFDGLANCNFSM4HVAQSUQ
>
> .
>
--
*John Foliot* | Principal Accessibility Strategist | W3C AC Representative
Deque Systems - Accessibility for Good
deque.com
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub
<#770?email_source=notifications&email_token=ABL6VSVJRHQP4IKKNGBKQITPZFEN5A5CNFSM4HVAQSU2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXDUC4I#issuecomment-499597681>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ABL6VSQEDC3NW3V7677C7ITPZFEN5ANCNFSM4HVAQSUQ>
.
|
Clear, added to MATF doc to discuss, thanks! |
Much of the discussion on #542 was around deprecating 4.1.1 if it can be demonstrated that issues that are flagged as 4.1.1 issues all either are issues against other SC. It sounds like the discussion is at least partly around adding a new SC to capture aria-related issues. Is it reasonable to address these as separate questions and issues? |
+1 for a new SC. I've seen 4.1.1 used to argue that a PDF document should have a Document element at the root of it's tag tree. While I think it is a bit of a stretch to see a PDF tag structure as a markup language, it clearly has properties in common with markup languages. So, if we go the route of a new SC to express that only valid nested roles are allowed, it would be good to think of the above case as well. Basically, I think we would like to see that people don't put things in something that is eventually rendered to an accessibility tree that mess up the resulting role structure. It being HTML, ARIA, a PDF tag tree or may be in the future an accessibility tree generated by some javascript. |
I would like it to also be relevant to ePub.
…On Thu, Jun 6, 2019, 5:56 PM Bram Duvigneau ***@***.***> wrote:
+1 for a new SC.
I've seen 4.1.1 used to argue that a PDF document should have a Document
element at the root of it's tag tree. While I think it is a bit of a
stretch to see a PDF tag structure as a markup language, it clearly has
properties in common with markup languages.
So, if we go the route of a new SC to express that only valid nested roles
are allowed, it would be good to think of the above case as well.
Basically, I think we would like to see that people don't put things in
something that is eventually rendered to an accessibility tree that mess up
the resulting role structure. It being HTML, ARIA, a PDF tag tree or may be
in the future an accessibility tree generated by some javascript.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#770?email_source=notifications&email_token=ABL6VSVKDJHZNTGODQFC7U3PZGBYHA5CNFSM4HVAQSU2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGODXEI4SY#issuecomment-499682891>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ABL6VSXYAFFCNZW2JRRW4ILPZGBYHANCNFSM4HVAQSUQ>
.
|
Here's a list of HTML / SVG / MathML features that use ID references taken from the relevant recommendations - that should help in figuring out whether duplicate IDs can have an impact not covered by other SC:
The SVG recommendation says IDs should be unique within the node tree - that has implications for SVG embedded in HTML: The MathML 3 recommendation is inconsistent about whether IDs should be unique. This normative text says Of note: there's also a section in the MathML 3 recommendation explaining how things like complete end tags and attribute quotes are not required for MathML in HTML: |
The use of duplicate IDs referenced in links via Ending up on the wrong part of the target page is difficult for people using magnifiers or screen readers. |
@dd8 Thanks for the list. That would have taken me a while to put together.
I agree with what most people are saying here, a new SC would be preferable. UpdateI've updated Requirement 3 in the top post, to include some of the attribute tests that Steve Faulkner's bookmarklet treats as failures for SC 4.1.1. I'm going to create a Doodle poll next for some of the people who volunteered to help work on this to come up with next steps. |
There are some missing since IDs can be used in any URL after the Fragments in URLs can only cause dupe id problems if the content type referenced can contain IDs. For example, the fragment in An example that currently fails SC 4.1.1 but needs considered if the SC is removed/replaced are skip links linked to duplicated IDs:
There's also an ambiguity on
|
@dd8 This doesn't necessarily fail any other SC - it may fail 2.4.1 Bypass blocks if the user agents make the skip link go to the wrong place, but if the user agents make the skip link go to the right place then functionally it is fine for users. |
@Ryladog Epub uses markup so it does apply already. |
Question is probably if it's a problem for all users, or something that disproportionately affects users with disabilities? |
I'd flag that under focus order, generally |
Andrew,
Ooops, you are right, it does have elements! Thanks!
** katie **
|
Bruce, we come across situations like the following <div role="button" tabindex="0"aria-label="Visit Google"> <a href="http://www.google.com"> |
@mraccess77 is that three examples or just one? I am reading it as three, but also I am not seeing how any of those fail against what 4.1.1 catches. Maybe not “nested according to their specification”? I feel like I need a more complete code sample to evaluate that. |
@bruce-usab HTML specification does not allow button inside of anchor, anchors inside of buttons, or inputs inside of anchors. So yes, these are 3 examples of nesting issues that can have impact on some AT in different ways. |
@mraccess77 It would be great to see functioning examples for those cases. |
I've been involved in features where this had been implemented dozens of times the last 2/3 years. Specially for sites where they use / create custom components / web components (with lots of ARIA). Problem is focus / programmatic associated descriptions / label / names gets mixed, not communicated properly or skipping of elements when Tabbing / Shift tabbing UICs. Also inconsistency in Tabbing OR Shift tabbing. (skipping one direction, not other direction). |
(my opinion: all of Robust should go, they are only means to make content P, O, and U... ;-) and place 4.1.3 under Perceivable / Adaptable) |
@alastc could I suggest changing the label for this in that case? |
PROPOSED RESPONSE: Out of an abundance of caution for backwards compatibility, and a desire not to cause confusion in the accessibility community over what removing 4.1.1 would mean, and concern about the number of group cycles that would be used up trying to achieve consensus which has been illusive on this issue, and also understanding the long history of 4.1.1 and validation discussions in general, we have decided not to deprecate this SC in WCAG. 2.2. @alastc (READY FOR SURVEY) |
in terms of confusion in the accessibility community, i actually see a lot more confusion currently over what exactly counts as a normative failure or not. any error reported by the HTML validator? or just a subset, and if so which ones? what about CSS, does that need to pass validation? what about markup that is sent invalid, but consistently error-corrected by browsers, or modified client-side and corrected via JS? similarly, how/when should authors check validity...just checking what the server sends, or checking the rendered DOM in browser after scripts/etc have had a chance to run? do they also need to test whenever some script generates new structures or otherwise modifies the existing DOM? when using ARIA, does an error in ARIA attributes/values count as a failure of 4.1.1? does it need to pass ARIA-in-HTML rules? IF 4.1.1 is to be retained, the understanding document should really clarify the situation a lot more. |
Nobody seems to have noticed that the code does actually violate SC 4.1.1 because of the duplicate |
|
Um, I wouldn't call that a decision yet. There is support for the deprecation, the form of that is on the survey for next week. |
It was a very interesting discussion! My gratitude to @tombrunet for mention of Jim Thatcher and IBM Also thanks to @TzviyaSiegman for pointing us to w3c process for deactivation since "deprecating" might not be enough. |
For clarity, and to record my comments - the issue was something I encountered when we created IBM Home Page Reader 3.x, particularly with the DOM walkers I was creating. IE's DOM parser at the time would stumble over things like I noted on the call - parsers have matured a lot over the last 20 years, and newer specs are more clear on how to handle a variety of authoring mistakes in consistent ways. Invalid element nesting is still bad practice, but not the accessibility issue that it was 20 years ago. |
Shouldn't this be under the 4.1.1 Label? |
if it makes you happy, @mgifford ... ;) |
Current status: We're moving to deprecate (remove) 4.1.1 in WCAG 2.2. Not finalised yet, we'll need a CFC on that. If that passes this issue can be closed. |
The January 2023 Candidate Recommendation has marked SC 4.1.1 as obsolete and has removed the success criterion. Is this issue being kept open for the sake of WCAG 2.0 and/or WCAG 2.1? |
We've now decided the actions for 2.2 (removal) and 2.1/2.0 (adding a note), so closing this issue. |
The top card of this issue will be updated as this work progresses
The purpose of this issue is to determine whether or not WCAG 2.1, success criterion 4.1.1 Parsing is still relevant to the accessibility of web content for people with disabilities. The web accessibility landscape has changes significantly since this criterion was proposed in 2008. Many accessibility experts are of the opinion that this success criterion is largely irrelevant, and that the part that is still relevant is addressed by other success criteria. If this is true, success criterion 4.1.1 could potentially be deprecated as part of WCAG 2.2.
Plan of Action
For this proposal, we'll go through the following steps:
Background
Web technologies have developed significantly since the creation of WCAG 2.0, where this success criterion was introduced. In HTML 4.01 and older versions, there was no description of what to do with malformed HTML. This caused HTML parsers to behave differently in different environments. HTML 5.0 included a detailed definition of how to parse malformed HTML. This has ensured that all modern browsers parse HTML exactly the same way.
The second reason why 4.1.1 was relevant in 2008, was because assistive technologies frequently had their own build-in HTML parser. Rather than rely on the browser to build up the accessibility tree, assistive technologies would build their own accessibility tree based on the HTML of a page. Improvements in browsers and standardisation efforts have made the accessibility trees more reliable. Assistive technologies in 2019 use the accessibility tree directly, rather than parse HTML and build their own.
Step 1: Breakdown of 4.1.1 Parsing
Scope
Success criterion 4.1.1 is applicable to all content implemented in markup languages.
Requirement 1
This requirement can be broken down further:
A closing tag exists for each element that require a closing tag (such as
main
,h1
,strong
, etc.)None of the closing tags are for elements that do not allow closing tags (such as
img
,input
,meta
, etc.)Each closing tag has a corresponding opening tag positioned before the closing tag of its parent node (e.g.
<div><h1></h1></div>
rather than<div><h1></div></h1>
)Requirement 2
The root node of a document is an element that is allowed as the root node (e.g.
html
is the root of HTML documents, andsvg
for SVG documents)Each child node of an element is of a type allowed in its content model. (e.g.
p
is allowedstrong
, but noth1
)Requirement 3
This requirement is often "expanded" to mean attributes must be marked up correctly.
Elements do not contain duplicate attributes (e.g.
<p class="foo" class="bar">...</p>
should be<p class="foo bar">...</p>
, and<input readonly="readonly" readonly>
should be<input readonly>
)Unquoted attributes (under certain circumstances) * (e.g.
<p id=alexander-'the-great'>
should be<p id="alexander-'the-great'">
or<p id=alexander-the-great>
)Mismatched quotes on attributes * (e.g.
<p id="main'>
should be<p id="main">
or<p id='main'>
)Attributes not space separated * (e.g.
<p id="main"class="main">
should be<p id="main" class="main">
)Attributes are not malformed * (e.g.
<p id:"main">
should be<p id="main">
))*: It is debatable whether or not points 2 through 5 are required by the success criterion. Either way it is worth exploring whether or not these cause accessibility issues.
The same attribute and attribute + value combination can exist on different elements, just not on the same element.
Requirement 4
IDs used in IDREFs are unique (e.g
<label for="name">name</label><input id="name">
)IDs used referenced by internal links are unique (e.g
<h1 id="hd1"><a href="#hd1">Heading 1</a></h1>
)IDs used on user interface components are unique (e.g
<button id="submit">Submit</button>
)IDs used on any element unique (e.g
<p id="my-style-be4d-c66d4b51819f">...</p>
)Note 1: IDs in different DOM trees are not required to be unique. The same ID can exist in different shadow DOM trees, since ID referencing across different trees is not valid.
Note 2: Elements hidden through CSS are not allowed duplicate IDs. IDREFs work regardless of if an element is visible. For example, aria-labelledby can use hidden elements for the computation of an accessible name.
Step 2: Scope "Markup languges"
In order for any markup language to be relevant for SC 4.1.1 Parsing, it must meet the following requirements:
To do: Fill out the table
Step 3: Assistive Technologies
TBD as part of step 3.
Step 4: Testing
TBD as part of step 4.
Step 5: Conclusion And Recommendations
TBD as part of step 5.
The text was updated successfully, but these errors were encountered: