-
Notifications
You must be signed in to change notification settings - Fork 6.8k
Description
Is this a regression?
- Yes, this behavior used to work in the previous version
The previous version in which this bug was not present was
No response
Description
When a <textarea> with cdkTextareaAutosize has its width set to auto and sits flush against the edges of its parent container, autosize miscalculates its height when the parent container acquires a vertical scrollbar (typically when overflow-y: auto or scroll is set).
As soon as the parent container shows a vertical scrollbar - slightly reducing the effective available width - the autosize clone measures text wrapping differently, causing the textarea to underestimate the required number of rows. This results in clipped and partially hidden text.
Reproduction
StackBlitz link: https://stackblitz.com/edit/5xmbl7sj-bxb7txwe?file=src%2Fexample%2Ftext-field-autosize-textarea-example.html
Steps to reproduce:
- Open the StackBlitz Link above
- Observe the
<div>container withoverflow-y: autoand the<textarea>component usingcdkTextareaAutosize - Resize the viewport so the container becomes narrow enough to easily trigger a scrollbar
- Insert text until the text area is filled and looks something like this, such that the scrollbar is triggered
- Insert another letter like
a, note how it disappears - Use the cursor to navigate to the bottom of the text and note how the top of the text in the
textareais clipping.
Expected Behavior
cdkTextareaAutosize should correctly measure the content height even when the parent container introduces a scrollbar that slightly changes the available width. The textarea should always fully display its content without clipping or requiring manual resizing.
Actual Behavior
When the container’s scrollbar appears, the autosize clone measures text wrapping as if no scrollbar were present. This results in a mismatch between measured and actual layout width, underestimating the required height by roughly one line. The resulting height is underestimated by roughly one line, leading to visible clipping.
Environment
- Angular:
20.2.4 - CDK/Material:
20.2.2 - Browser(s):
Edge (141.0.3537.85), Chrome (141.0.7390.108)possibly more (tested on these) - Operating System (e.g. Windows, macOS, Ubuntu):
Windows