-
Notifications
You must be signed in to change notification settings - Fork 360
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
Data grid keyboard navigation examples get 'stuck' on links and can't navigate beyond them #3208
Comments
I can't reproduce the problem you describe (with Firefox, Edge and Chrome), hence my question as to whether you might be using a screen reader. It could be a bug in a screen reader that causes the screen reader to switch from form mode (which enables arrow key navigation) to reading mode (because not the gridcell with link receives the focus, but the link itself) |
@JAWS-test thank you - yes that's it - NVDA - I will raise with them. |
I was able to reproduce the problem with NVDA. It does not occur with JAWS. The problem actually occurs because NVDA is only in form mode as long as a gridcell has the focus. As soon as an element within the gridcell, which normally causes reading mode, receives the focus, NVDA switches to reading mode. I don't think the ARIA specification says anything specific about how screen readers should behave when elements within the gridcell receive focus. Therefore you are welcome to submit a ticket to NVDA (https://github.com/nvaccess/nvda/issues), at the same time I would like to ask you to open the ticket here again, because the ARIA WG should discuss whether a screen reader must always remain in form mode with a gridcell. What if the gridcell contains text and I switch to edit mode with F2: There I would expect to be able to read the text content without receiving focus with the keyboard. That's why NVDA's decision to switch to reading mode when focussing on a link is not necessarily far-fetched. |
Thank you. I started to submit a ticket to NVDA but concluded like you that perhaps it wasn't an issue, although I didn't get as reasoned and answer as you :) I did start a codepen just to understand what events were firing when with and without NVDA, if it's helpful: https://codepen.io/mattparker_l/pen/bNbYjRO I don't use a screen reader or generally keyboard navigation; I'm trying to develop well for those that do. So if this is discussed further, FWIW I found it very confusing trying to navigate around a table that contains form elements in some cells but not others using NVDA. But my expectations shouldn't count for much here! |
See: https://www.w3.org/WAI/ARIA/apg/patterns/grid/#gridNav_focus |
This is an NVDA bug. The ARIA-AT project will write tests for this behavior. We are about a year behind getting to grid. The challenges that were severely impeding test writing and review are largely behind us now, so I am reasonably confident we will get to grid in 2025. When focus is inside of a grid, the expectation, like with other composite widgets, is that screen readers that support automatic mode switching will enable web applications to receive keyboard events by default. Note that VoiceOver users need to manually control this behavior at all times. |
I think this may be a browser issue but I can't find any reports of it anywhere.
In the simple example at https://www.w3.org/WAI/ARIA/apg/patterns/grid/examples/data-grids/#ex1_label
This happens on Edge 131 and Firefox 133 on Windows. It happens on the Codepen version, and variations of it on other examples.
Any interactive element like a button in the table cell does not, as far as I can tell, allow
keydown
events to bubble beyond the element and so focus can't be moved to other cells.I also don't think that arrow key events are being fired on the elements like links or buttons (although e.g. a
<select>
does seem to where up and down have some natural meaning).(apologies in advance if this is not the best place for this type of issue. I have searched elsewhere and come up with nothing).
The text was updated successfully, but these errors were encountered: