You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
bug(cdkTable & virtual scroll): Virtual scrolling in CDK table provides incorrect information to screen readers and causes focus/context loss during navigation #33393
Yes, this behavior used to work in the previous version
The previous version in which this bug was not present was
No response
Description
The recently introduced virtual scrolling support for CDK tables appears to have accessibility issues when used with screen readers.
Because rows are dynamically removed and added to the DOM, screen reader users can receive incorrect table information and lose their position while navigating through table content.
Impact
This issue significantly affects accessibility for users who rely on screen readers and may make large virtualized tables difficult or impossible to navigate reliably.
Start a screen reader (e.g. NVDA, JAWS, or VoiceOver).
Navigate to the table and begin reading/navigating through rows using screen reader table navigation commands.
Continue navigating down the table until virtual scrolling is triggered and previously rendered rows are removed from the DOM while new rows are rendered.
Expected Behavior
Screen readers should be able to determine the actual total number of rows in the table, not only the rows currently rendered in the DOM.
Navigation through table rows should remain stable when virtual scrolling updates the rendered range.
Users should not unexpectedly jump to different data records while their screen reader focus remains on the same DOM row.
The virtual scrolling implementation should preserve a consistent and accessible experience for assistive technology users.
Actual Behavior
Current Behavior
Issue 1: Incorrect row count
Screen readers report an incorrect number of rows in the table.
Since only a subset of rows is rendered at any given time, assistive technologies may perceive only the currently rendered rows instead of the actual total number of rows in the dataset.
For example, a table containing thousands of rows may be announced as having only the number of rows currently present in the DOM.
Issue 2: Row content changes while screen reader focus remains on the same row
When navigating the table with a screen reader, virtual scrolling can remove rows from the beginning of the DOM and append new rows at the end.
Example:
The user navigates down to row 30.
Virtual scrolling is triggered.
Rows 1–10 are removed from the DOM.
Rows 31–40 are added.
The screen reader remains positioned on what it considers "row 30".
However, the DOM element representing that row may now contain different content than before. As a result, the user effectively jumps to another record without receiving clear feedback that the underlying content has changed.
This makes navigation confusing and can cause users to lose context within the table.
Environment
Angular: 22
CDK/Material: RC
Browser(s): Chrome 149.0.7827.103
Operating System (e.g. Windows, macOS, Ubuntu): macOS 26.5.1 (25F80)
Is this a regression?
The previous version in which this bug was not present was
No response
Description
The recently introduced virtual scrolling support for CDK tables appears to have accessibility issues when used with screen readers.
Because rows are dynamically removed and added to the DOM, screen reader users can receive incorrect table information and lose their position while navigating through table content.
Impact
This issue significantly affects accessibility for users who rely on screen readers and may make large virtualized tables difficult or impossible to navigate reliably.
Reproduction
Screen.Recording.2026-06-15.at.08.50.22.mov
https://rc.material.angular.dev/cdk/table/overview#alternate-html-to-using-native-table
Steps to reproduce:
Expected Behavior
Screen readers should be able to determine the actual total number of rows in the table, not only the rows currently rendered in the DOM.
Navigation through table rows should remain stable when virtual scrolling updates the rendered range.
Users should not unexpectedly jump to different data records while their screen reader focus remains on the same DOM row.
The virtual scrolling implementation should preserve a consistent and accessible experience for assistive technology users.
Actual Behavior
Current Behavior
Issue 1: Incorrect row count
Screen readers report an incorrect number of rows in the table.
Since only a subset of rows is rendered at any given time, assistive technologies may perceive only the currently rendered rows instead of the actual total number of rows in the dataset.
For example, a table containing thousands of rows may be announced as having only the number of rows currently present in the DOM.
Issue 2: Row content changes while screen reader focus remains on the same row
When navigating the table with a screen reader, virtual scrolling can remove rows from the beginning of the DOM and append new rows at the end.
Example:
The user navigates down to row 30.
Virtual scrolling is triggered.
Rows 1–10 are removed from the DOM.
Rows 31–40 are added.
The screen reader remains positioned on what it considers "row 30".
However, the DOM element representing that row may now contain different content than before. As a result, the user effectively jumps to another record without receiving clear feedback that the underlying content has changed.
This makes navigation confusing and can cause users to lose context within the table.
Environment